123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762 |
- define("amber_core/Kernel-Collections", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_vm/globals", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st, globals){
- smalltalk.addPackage('Kernel-Collections');
- smalltalk.packages["Kernel-Collections"].transport = {"type":"amd","amdNamespace":"amber_core"};
- smalltalk.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:`";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "=",
- protocol: 'comparing',
- fn: function (anAssociation){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $3,$2,$5,$4,$6,$1;
- $3=self._class();
- $ctx1.sendIdx["class"]=1;
- $2=_st($3).__eq(_st(anAssociation)._class());
- $ctx1.sendIdx["="]=1;
- $1=_st($2)._and_((function(){
- return smalltalk.withContext(function($ctx2) {
- $5=self._key();
- $ctx2.sendIdx["key"]=1;
- $4=_st($5).__eq(_st(anAssociation)._key());
- $ctx2.sendIdx["="]=2;
- return _st($4)._and_((function(){
- return smalltalk.withContext(function($ctx3) {
- $6=self._value();
- $ctx3.sendIdx["value"]=1;
- return _st($6).__eq(_st(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 ]]",
- messageSends: ["and:", "=", "class", "key", "value"],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "key",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@key"];
- return $1;
- },
- args: [],
- source: "key\x0a\x09^ key",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "key:",
- protocol: 'accessing',
- fn: function (aKey){
- var self=this;
- self["@key"]=aKey;
- return self},
- args: ["aKey"],
- source: "key: aKey\x0a\x09key := aKey",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(self._key())._printOn_(aStream);
- $ctx1.sendIdx["printOn:"]=1;
- _st(aStream)._nextPutAll_(" -> ");
- _st(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",
- messageSends: ["printOn:", "key", "nextPutAll:", "value"],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "value",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@value"];
- return $1;
- },
- args: [],
- source: "value\x0a\x09^ value",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "value:",
- protocol: 'accessing',
- fn: function (aValue){
- var self=this;
- self["@value"]=aValue;
- return self},
- args: ["aValue"],
- source: "value: aValue\x0a\x09value := aValue",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Association);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "key:value:",
- protocol: 'instance creation',
- fn: function (aKey,aValue){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._key_(aKey);
- _st($2)._value_(aValue);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["key:", "new", "value:", "yourself"],
- referencedClasses: []
- }),
- globals.Association.klass);
- smalltalk.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`.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "bucketOfElement:",
- protocol: 'accessing',
- fn: function (anObject){
- var self=this;
- 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},
- args: ["anObject"],
- source: "bucketOfElement: anObject\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var buckets = self['@buckets'];
- var keys = Object.keys(buckets);
- for (var i = 0; i < keys.length; ++i) { buckets[keys[i]]._do_(aBlock); }
- ;
- return self},
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "hashBlock:",
- protocol: 'accessing',
- fn: function (aBlock){
- var self=this;
- self["@hashBlock"]=aBlock;
- return self},
- args: ["aBlock"],
- source: "hashBlock: aBlock\x0a\x09hashBlock := aBlock",
- messageSends: [],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "initialize",
- protocol: 'initialization',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.BucketStore.superclass.fn.prototype._initialize.apply(_st(self), []);
- self._removeAll();
- return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},globals.BucketStore)})},
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09self removeAll",
- messageSends: ["initialize", "removeAll"],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "newBucket",
- protocol: 'private',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"newBucket",{},globals.BucketStore)})},
- args: [],
- source: "newBucket\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- self['@buckets'] = Object.create(null);;
- return self},
- args: [],
- source: "removeAll\x0a\x09<self['@buckets'] = Object.create(null);>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.BucketStore);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "hashBlock:",
- protocol: 'instance creation',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._hashBlock_(aBlock);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["hashBlock:", "new", "yourself"],
- referencedClasses: []
- }),
- globals.BucketStore.klass);
- smalltalk.addClass('ArrayBucketStore', globals.BucketStore, [], 'Kernel-Collections');
- globals.ArrayBucketStore.comment="I am a concrete `BucketStore` with buckets being instance of `Array`.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "newBucket",
- protocol: 'private',
- fn: function (){
- var self=this;
- var $1;
- $1=[];
- return $1;
- },
- args: [],
- source: "newBucket\x0a\x09^ #()",
- messageSends: [],
- referencedClasses: []
- }),
- globals.ArrayBucketStore);
- smalltalk.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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: ",",
- protocol: 'copying',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._copy();
- _st($2)._addAll_(aCollection);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,",",{aCollection:aCollection},globals.Collection)})},
- args: ["aCollection"],
- source: ", aCollection\x0a\x09^ self copy\x0a\x09\x09addAll: aCollection;\x0a\x09\x09yourself",
- messageSends: ["addAll:", "copy", "yourself"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "addAll:",
- protocol: 'adding/removing',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(aCollection)._do_((function(each){
- return smalltalk.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",
- messageSends: ["do:", "add:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "allSatisfy:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(each);
- if(! smalltalk.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",
- messageSends: ["do:", "ifFalse:", "value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "anyOne",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $early={};
- try {
- self._ifEmpty_((function(){
- return smalltalk.withContext(function($ctx2) {
- return self._error_("Collection is empty");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- throw $early=[each];
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)})}));
- 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 ]",
- messageSends: ["ifEmpty:", "error:", "do:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "anySatisfy:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(each);
- if(smalltalk.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",
- messageSends: ["do:", "ifTrue:", "value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asArray",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $Array(){return globals.Array||(typeof Array=="undefined"?nil:Array)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($Array())._withAll_(self);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asArray",{},globals.Collection)})},
- args: [],
- source: "asArray\x0a\x09^ Array withAll: self",
- messageSends: ["withAll:"],
- referencedClasses: ["Array"]
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asJSON",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._asArray())._collect_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each)._asJSON();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJSON",{},globals.Collection)})},
- args: [],
- source: "asJSON\x0a\x09^ self asArray collect: [ :each | each asJSON ]",
- messageSends: ["collect:", "asArray", "asJSON"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asOrderedCollection",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._asArray();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asOrderedCollection",{},globals.Collection)})},
- args: [],
- source: "asOrderedCollection\x0a\x09^ self asArray",
- messageSends: ["asArray"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asSet",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $Set(){return globals.Set||(typeof Set=="undefined"?nil:Set)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($Set())._withAll_(self);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asSet",{},globals.Collection)})},
- args: [],
- source: "asSet\x0a\x09^ Set withAll: self",
- messageSends: ["withAll:"],
- referencedClasses: ["Set"]
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "collect:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var stream;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- stream=_st(_st(self._class())._new())._writeStream();
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(stream)._nextPut_(_st(aBlock)._value_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=_st(stream)._contents();
- return $1;
- }, 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",
- messageSends: ["writeStream", "new", "class", "do:", "nextPut:", "value:", "contents"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "contains:",
- protocol: 'testing',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- self._deprecatedAPI();
- $1=self._anySatisfy_(aBlock);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"contains:",{aBlock:aBlock},globals.Collection)})},
- args: ["aBlock"],
- source: "contains: aBlock\x0a\x09self deprecatedAPI.\x0a\x0a\x09^ self anySatisfy: aBlock",
- messageSends: ["deprecatedAPI", "anySatisfy:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "copyWith:",
- protocol: 'copying',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._copy();
- _st($2)._add_(anObject);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"copyWith:",{anObject:anObject},globals.Collection)})},
- args: ["anObject"],
- source: "copyWith: anObject\x0a\x09^ self copy add: anObject; yourself",
- messageSends: ["add:", "copy", "yourself"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "copyWithAll:",
- protocol: 'copying',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._copy();
- _st($2)._addAll_(aCollection);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"copyWithAll:",{aCollection:aCollection},globals.Collection)})},
- args: ["aCollection"],
- source: "copyWithAll: aCollection\x0a\x09^ self copy addAll: aCollection; yourself",
- messageSends: ["addAll:", "copy", "yourself"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "copyWithoutAll:",
- protocol: 'copying',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._reject_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(aCollection)._includes_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["reject:", "includes:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "detect:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._detect_ifNone_(aBlock,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"detect:",{aBlock:aBlock},globals.Collection)})},
- args: ["aBlock"],
- source: "detect: aBlock\x0a\x09^ self detect: aBlock ifNone: [ self errorNotFound ]",
- messageSends: ["detect:ifNone:", "errorNotFound"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "detect:ifNone:",
- protocol: 'enumerating',
- fn: function (aBlock,anotherBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:separatedBy:",
- protocol: 'enumerating',
- fn: function (aBlock,anotherBlock){
- var self=this;
- var actionBeforeElement;
- return smalltalk.withContext(function($ctx1) {
- actionBeforeElement=(function(){
- return smalltalk.withContext(function($ctx2) {
- actionBeforeElement=anotherBlock;
- return actionBeforeElement;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})});
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- _st(actionBeforeElement)._value();
- return _st(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 ]",
- messageSends: ["do:", "value", "value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "errorNotFound",
- protocol: 'error handling',
- fn: function (){
- var self=this;
- return smalltalk.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'",
- messageSends: ["error:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "ifEmpty:",
- protocol: 'testing',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._isEmpty();
- $1=_st($2)._ifTrue_ifFalse_(aBlock,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, 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: aBlock\x0a\x09\x09ifFalse: [ self ]",
- messageSends: ["ifTrue:ifFalse:", "isEmpty"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "ifEmpty:ifNotEmpty:",
- protocol: 'testing',
- fn: function (aBlock,anotherBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._isEmpty();
- $1=_st($2)._ifTrue_ifFalse_(aBlock,anotherBlock);
- return $1;
- }, 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: aBlock\x0a\x09\x09ifFalse: anotherBlock",
- messageSends: ["ifTrue:ifFalse:", "isEmpty"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "ifNotEmpty:",
- protocol: 'testing',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._notEmpty();
- $1=_st($2)._ifTrue_ifFalse_(aBlock,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"ifNotEmpty:",{aBlock:aBlock},globals.Collection)})},
- args: ["aBlock"],
- source: "ifNotEmpty: aBlock\x0a\x09^ self notEmpty\x0a\x09\x09ifTrue: aBlock\x0a\x09\x09ifFalse: [ self ]",
- messageSends: ["ifTrue:ifFalse:", "notEmpty"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "ifNotEmpty:ifEmpty:",
- protocol: 'testing',
- fn: function (aBlock,anotherBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._notEmpty();
- $1=_st($2)._ifTrue_ifFalse_(aBlock,anotherBlock);
- return $1;
- }, 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\x0a\x09\x09ifFalse: anotherBlock",
- messageSends: ["ifTrue:ifFalse:", "notEmpty"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includes:",
- protocol: 'testing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._anySatisfy_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},globals.Collection)})},
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ self anySatisfy: [ :each | each = anObject ]",
- messageSends: ["anySatisfy:", "="],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "inject:into:",
- protocol: 'enumerating',
- fn: function (anObject,aBlock){
- var self=this;
- var result;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- result=anObject;
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- result=_st(aBlock)._value_value_(result,each);
- return result;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=result;
- return $1;
- }, 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",
- messageSends: ["do:", "value:value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "intersection:",
- protocol: 'enumerating',
- fn: function (aCollection){
- var self=this;
- var set,outputSet;
- function $Set(){return globals.Set||(typeof Set=="undefined"?nil:Set)}
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$3;
- set=self._asSet();
- outputSet=_st($Set())._new();
- _st(aCollection)._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $2=_st(set)._includes_(each);
- $ctx2.sendIdx["includes:"]=1;
- $1=_st($2)._and_((function(){
- return smalltalk.withContext(function($ctx3) {
- return _st(_st(outputSet)._includes_(each))._not();
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,2)})}));
- if(smalltalk.assert($1)){
- return _st(outputSet)._add_(each);
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $3=_st(self._class())._withAll_(_st(outputSet)._asArray());
- return $3;
- }, 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",
- messageSends: ["asSet", "new", "do:", "ifTrue:", "and:", "includes:", "not", "add:", "withAll:", "class", "asArray"],
- referencedClasses: ["Set"]
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isEmpty",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._size()).__eq((0));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"isEmpty",{},globals.Collection)})},
- args: [],
- source: "isEmpty\x0a\x09^ self size = 0",
- messageSends: ["=", "size"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "noneSatisfy:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- var $early={};
- try {
- self._do_((function(item){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(item);
- if(smalltalk.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",
- messageSends: ["do:", "ifTrue:", "value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "notEmpty",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._isEmpty())._not();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"notEmpty",{},globals.Collection)})},
- args: [],
- source: "notEmpty\x0a\x09^ self isEmpty not",
- messageSends: ["not", "isEmpty"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "occurrencesOf:",
- protocol: 'accessing',
- fn: function (anObject){
- var self=this;
- var tally;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- tally=(0);
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(anObject).__eq(each);
- if(smalltalk.assert($1)){
- tally=_st(tally).__plus((1));
- return tally;
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $2=tally;
- return $2;
- }, 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",
- messageSends: ["do:", "ifTrue:", "=", "+"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "putOn:",
- protocol: 'streaming',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(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 ]",
- messageSends: ["do:", "putOn:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "reject:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._select_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(_st(aBlock)._value_(each)).__eq(false);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["select:", "=", "value:"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._remove_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"remove:",{anObject:anObject},globals.Collection)})},
- args: ["anObject"],
- source: "remove: anObject\x0a\x09^ self remove: anObject ifAbsent: [ self errorNotFound ]",
- messageSends: ["remove:ifAbsent:", "errorNotFound"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (anObject,aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"removeAll",{},globals.Collection)})},
- args: [],
- source: "removeAll\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "select:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var stream;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- stream=_st(_st(self._class())._new())._writeStream();
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(each);
- if(smalltalk.assert($1)){
- return _st(stream)._nextPut_(each);
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $2=_st(stream)._contents();
- return $2;
- }, 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",
- messageSends: ["writeStream", "new", "class", "do:", "ifTrue:", "value:", "nextPut:", "contents"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "select:thenCollect:",
- protocol: 'enumerating',
- fn: function (selectBlock,collectBlock){
- var self=this;
- var stream;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- stream=_st(_st(self._class())._new())._writeStream();
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(selectBlock)._value_(each);
- $ctx2.sendIdx["value:"]=1;
- if(smalltalk.assert($1)){
- return _st(stream)._nextPut_(_st(collectBlock)._value_(each));
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $2=_st(stream)._contents();
- return $2;
- }, 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",
- messageSends: ["writeStream", "new", "class", "do:", "ifTrue:", "value:", "nextPut:", "contents"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"size",{},globals.Collection)})},
- args: [],
- source: "size\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.Collection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "heliosClass",
- protocol: 'helios',
- fn: function (){
- var self=this;
- return "collection";
- },
- args: [],
- source: "heliosClass\x0a\x09^ 'collection'",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "new:",
- protocol: 'instance creation',
- fn: function (anInteger){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._new();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"new:",{anInteger:anInteger},globals.Collection.klass)})},
- args: ["anInteger"],
- source: "new: anInteger\x0a\x09^ self new",
- messageSends: ["new"],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:",
- protocol: 'instance creation',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._add_(anObject);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["add:", "new", "yourself"],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:with:",
- protocol: 'instance creation',
- fn: function (anObject,anotherObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._add_(anObject);
- $ctx1.sendIdx["add:"]=1;
- _st($2)._add_(anotherObject);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["add:", "new", "yourself"],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:with:with:",
- protocol: 'instance creation',
- fn: function (firstObject,secondObject,thirdObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._add_(firstObject);
- $ctx1.sendIdx["add:"]=1;
- _st($2)._add_(secondObject);
- $ctx1.sendIdx["add:"]=2;
- _st($2)._add_(thirdObject);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["add:", "new", "yourself"],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "withAll:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._addAll_(aCollection);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["addAll:", "new", "yourself"],
- referencedClasses: []
- }),
- globals.Collection.klass);
- smalltalk.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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:",
- protocol: 'accessing',
- fn: function (anIndex){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_ifAbsent_(anIndex,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["at:ifAbsent:", "errorNotFound"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsentPut:",
- protocol: 'accessing',
- fn: function (aKey,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_ifAbsent_(aKey,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._at_put_(aKey,_st(aBlock)._value());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["at:ifAbsent:", "at:put:", "value"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifPresent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_ifPresent_ifAbsent_(anIndex,aBlock,(function(){
- return smalltalk.withContext(function($ctx2) {
- return nil;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, 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 ]",
- messageSends: ["at:ifPresent:ifAbsent:"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:put:",
- protocol: 'accessing',
- fn: function (anIndex,anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:",
- protocol: 'accessing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._indexOf_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["indexOf:ifAbsent:", "errorNotFound"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:do:",
- protocol: 'enumarating',
- fn: function (anotherCollection,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._withIndexDo_((function(each,index){
- return smalltalk.withContext(function($ctx2) {
- return _st(aBlock)._value_value_(each,_st(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) ]",
- messageSends: ["withIndexDo:", "value:value:", "at:"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "withIndexDo:",
- protocol: 'enumarating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.IndexableCollection);
- smalltalk.addClass('AssociativeCollection', globals.IndexableCollection, [], 'Kernel-Collections');
- globals.AssociativeCollection.comment="I am a base class for object-indexed collections (Dictionary et.al.).";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "=",
- protocol: 'comparing',
- fn: function (anAssocitativeCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$4,$3,$6,$5;
- $2=self._class();
- $ctx1.sendIdx["class"]=1;
- $1=_st($2).__eq(_st(anAssocitativeCollection)._class());
- $ctx1.sendIdx["="]=1;
- if(! smalltalk.assert($1)){
- return false;
- };
- $4=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=_st($4).__eq(_st(anAssocitativeCollection)._size());
- $ctx1.sendIdx["="]=2;
- if(! smalltalk.assert($3)){
- return false;
- };
- $6=self._associations();
- $ctx1.sendIdx["associations"]=1;
- $5=_st($6).__eq(_st(anAssocitativeCollection)._associations());
- return $5;
- }, 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",
- messageSends: ["ifFalse:", "=", "class", "size", "associations"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:",
- protocol: 'adding/removing',
- fn: function (anAssociation){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._at_put_(_st(anAssociation)._key(),_st(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",
- messageSends: ["at:put:", "key", "value"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "addAll:",
- protocol: 'adding/removing',
- fn: function (anAssociativeCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.AssociativeCollection.superclass.fn.prototype._addAll_.apply(_st(self), [_st(anAssociativeCollection)._associations()]);
- 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",
- messageSends: ["addAll:", "associations"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asDictionary",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $Dictionary(){return globals.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($Dictionary())._from_(self._associations());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asDictionary",{},globals.AssociativeCollection)})},
- args: [],
- source: "asDictionary\x0a\x09^ Dictionary from: self associations",
- messageSends: ["from:", "associations"],
- referencedClasses: ["Dictionary"]
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asHashedCollection",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $HashedCollection(){return globals.HashedCollection||(typeof HashedCollection=="undefined"?nil:HashedCollection)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($HashedCollection())._from_(self._associations());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asHashedCollection",{},globals.AssociativeCollection)})},
- args: [],
- source: "asHashedCollection\x0a\x09^ HashedCollection from: self associations",
- messageSends: ["from:", "associations"],
- referencedClasses: ["HashedCollection"]
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asJSON",
- protocol: 'converting',
- fn: function (){
- var self=this;
- var hash;
- function $HashedCollection(){return globals.HashedCollection||(typeof HashedCollection=="undefined"?nil:HashedCollection)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- hash=_st($HashedCollection())._new();
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(hash)._at_put_(key,_st(value)._asJSON());
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)})}));
- $1=hash;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJSON",{hash:hash},globals.AssociativeCollection)})},
- args: [],
- source: "asJSON\x0a\x09| hash |\x0a\x09hash := HashedCollection new.\x0a\x09self keysAndValuesDo: [ :key :value |\x0a\x09\x09hash at: key put: value asJSON ].\x0a\x09^ hash",
- messageSends: ["new", "keysAndValuesDo:", "at:put:", "asJSON"],
- referencedClasses: ["HashedCollection"]
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "associations",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var associations;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- associations=[];
- self._associationsDo_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(associations)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=associations;
- return $1;
- }, 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",
- messageSends: ["associationsDo:", "add:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "associationsDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- function $Association(){return globals.Association||(typeof Association=="undefined"?nil:Association)}
- return smalltalk.withContext(function($ctx1) {
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(aBlock)._value_(_st($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) ]",
- messageSends: ["keysAndValuesDo:", "value:", "key:value:"],
- referencedClasses: ["Association"]
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: 'accessing',
- fn: function (aKey,aBlock,anotherBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._includesKey_(aKey);
- if(smalltalk.assert($2)){
- $1=_st(aBlock)._value_(self._at_(aKey));
- } else {
- $1=_st(anotherBlock)._value();
- };
- return $1;
- }, 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 ]",
- messageSends: ["ifTrue:ifFalse:", "includesKey:", "value:", "at:", "value"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "collect:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var newDict;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- newDict=_st(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(newDict)._at_put_(key,_st(aBlock)._value_(value));
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)})}));
- $1=newDict;
- return $1;
- }, 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",
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:", "value:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "deepCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- var copy;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- copy=_st(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(copy)._at_put_(key,_st(value)._deepCopy());
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)})}));
- $1=copy;
- return $1;
- }, 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",
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:", "deepCopy"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "detect:ifNone:",
- protocol: 'enumerating',
- fn: function (aBlock,anotherBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._values())._detect_ifNone_(aBlock,anotherBlock);
- return $1;
- }, 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",
- messageSends: ["detect:ifNone:", "values"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["valuesDo:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includes:",
- protocol: 'enumerating',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._values())._includes_(anObject);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},globals.AssociativeCollection)})},
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ self values includes: anObject",
- messageSends: ["includes:", "values"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includesKey:",
- protocol: 'testing',
- fn: function (aKey){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._keys())._detect_ifNone_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(self._at_(each)).__eq(anObject);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}),aBlock);
- return $1;
- }, 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",
- messageSends: ["detect:ifNone:", "keys", "=", "at:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keyAtValue:",
- protocol: 'accessing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._keyAtValue_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return self._errorNotFound();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"keyAtValue:",{anObject:anObject},globals.AssociativeCollection)})},
- args: ["anObject"],
- source: "keyAtValue: anObject\x0a\x09^ self keyAtValue: anObject ifAbsent: [ self errorNotFound ]",
- messageSends: ["keyAtValue:ifAbsent:", "errorNotFound"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keyAtValue:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._indexOf_ifAbsent_(anObject,aBlock);
- return $1;
- }, 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",
- messageSends: ["indexOf:ifAbsent:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keys",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"keys",{},globals.AssociativeCollection)})},
- args: [],
- source: "keys\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keysAndValuesDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._keysDo_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(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) ]",
- messageSends: ["keysDo:", "value:value:", "at:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keysDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.AssociativeCollection.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]);
- $ctx1.sendIdx["printOn:"]=1;
- _st(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- _st(self._associations())._do_separatedBy_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}),(function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(aStream)._nextPutAll_(" , ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- _st(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: ')'",
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:", "associations"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (aKey,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._removeKey_ifAbsent_(aKey,aBlock);
- return $1;
- }, 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",
- messageSends: ["removeKey:ifAbsent:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._keys())._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return self._removeKey_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"removeAll",{},globals.AssociativeCollection)})},
- args: [],
- source: "removeAll\x0a\x09^ self keys do: [ :each | self removeKey: each ]",
- messageSends: ["do:", "keys", "removeKey:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeKey:",
- protocol: 'adding/removing',
- fn: function (aKey){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._remove_(aKey);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"removeKey:",{aKey:aKey},globals.AssociativeCollection)})},
- args: ["aKey"],
- source: "removeKey: aKey\x0a\x09^ self remove: aKey",
- messageSends: ["remove:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeKey:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (aKey,aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "select:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var newDict;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- newDict=_st(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(value);
- if(smalltalk.assert($1)){
- return _st(newDict)._at_put_(key,value);
- };
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)})}));
- $2=newDict;
- return $2;
- }, 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",
- messageSends: ["new", "class", "keysAndValuesDo:", "ifTrue:", "value:", "at:put:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "shallowCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- var copy;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- copy=_st(self._class())._new();
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(copy)._at_put_(key,value);
- }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1,1)})}));
- $1=copy;
- return $1;
- }, 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",
- messageSends: ["new", "class", "keysAndValuesDo:", "at:put:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._keys())._size();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"size",{},globals.AssociativeCollection)})},
- args: [],
- source: "size\x0a\x09^ self keys size",
- messageSends: ["size", "keys"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "values",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"values",{},globals.AssociativeCollection)})},
- args: [],
- source: "values\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "valuesDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "withIndexDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._keysAndValuesDo_((function(key,value){
- return smalltalk.withContext(function($ctx2) {
- return _st(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 ]",
- messageSends: ["keysAndValuesDo:", "value:value:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "from:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- var newCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- newCollection=self._new();
- _st(aCollection)._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(newCollection)._add_(each);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=newCollection;
- return $1;
- }, 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",
- messageSends: ["new", "do:", "add:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromPairs:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._from_(aCollection);
- return $1;
- }, 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",
- messageSends: ["from:"],
- referencedClasses: []
- }),
- globals.AssociativeCollection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "newFromPairs:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- var newCollection;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$3,$4,$5;
- $2=_st(aCollection)._size();
- $ctx1.sendIdx["size"]=1;
- $1=_st($2)._even();
- if(! smalltalk.assert($1)){
- self._error_("#newFromPairs only accepts arrays of an even length");
- };
- newCollection=self._new();
- _st((1)._to_by_(_st(aCollection)._size(),(2)))._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $3=newCollection;
- $4=_st(aCollection)._at_(each);
- $ctx2.sendIdx["at:"]=1;
- return _st($3)._at_put_($4,_st(aCollection)._at_(_st(each).__plus((1))));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,2)})}));
- $5=newCollection;
- return $5;
- }, 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",
- messageSends: ["ifFalse:", "even", "size", "error:", "new", "do:", "to:by:", "at:put:", "at:", "+"],
- referencedClasses: []
- }),
- globals.AssociativeCollection.klass);
- smalltalk.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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsent:",
- protocol: 'accessing',
- fn: function (aKey,aBlock){
- var self=this;
- var index = self._positionOfKey_(aKey);
- return index >=0 ? self['@values'][index] : aBlock._value();
- ;
- return self},
- args: ["aKey", "aBlock"],
- source: "at: aKey ifAbsent: aBlock\x0a\x09<\x0a\x09\x09var index = self._positionOfKey_(aKey);\x0a\x09\x09return index >>=0 ? self['@values'][index] : aBlock._value();\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:put:",
- protocol: 'accessing',
- fn: function (aKey,aValue){
- var self=this;
- 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},
- args: ["aKey", "aValue"],
- source: "at: aKey put: aValue\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includesKey:",
- protocol: 'testing',
- fn: function (aKey){
- var self=this;
- return self._positionOfKey_(aKey) >= 0; ;
- return self},
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09< return self._positionOfKey_(aKey) >>= 0; >",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,aBlock){
- var self=this;
- var index;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- index=_st(self["@values"])._indexOf_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return (0);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- $2=_st(index).__eq((0));
- if(smalltalk.assert($2)){
- $1=_st(aBlock)._value();
- } else {
- $1=_st(self["@keys"])._at_(index);
- };
- return $1;
- }, 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 ]",
- messageSends: ["indexOf:ifAbsent:", "ifTrue:ifFalse:", "=", "value", "at:"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "initialize",
- protocol: 'initialization',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.Dictionary.superclass.fn.prototype._initialize.apply(_st(self), []);
- self["@keys"]=[];
- self["@values"]=[];
- return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},globals.Dictionary)})},
- args: [],
- source: "initialize\x0a\x09super initialize.\x0a\x09keys := #().\x0a\x09values := #()",
- messageSends: ["initialize"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keys",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self["@keys"])._copy();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"keys",{},globals.Dictionary)})},
- args: [],
- source: "keys\x0a\x09^ keys copy",
- messageSends: ["copy"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keysAndValuesDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self["@keys"])._with_do_(self["@values"],aBlock);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},globals.Dictionary)})},
- args: ["aBlock"],
- source: "keysAndValuesDo: aBlock\x0a\x09^ keys with: values do: aBlock",
- messageSends: ["with:do:"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keysDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self["@keys"])._do_(aBlock);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"keysDo:",{aBlock:aBlock},globals.Dictionary)})},
- args: ["aBlock"],
- source: "keysDo: aBlock\x0a\x09^ keys do: aBlock",
- messageSends: ["do:"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "positionOfKey:",
- protocol: 'private',
- fn: function (anObject){
- var self=this;
- var keys = self['@keys'];
- for(var i=0;i<keys.length;i++){
- if(keys[i].__eq(anObject)) { return i;}
- }
- return -1;
- ;
- return self},
- args: ["anObject"],
- source: "positionOfKey: anObject\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(self["@keys"])._removeAll();
- $ctx1.sendIdx["removeAll"]=1;
- _st(self["@values"])._removeAll();
- return self}, function($ctx1) {$ctx1.fill(self,"removeAll",{},globals.Dictionary)})},
- args: [],
- source: "removeAll\x0a\x09keys removeAll.\x0a\x09values removeAll",
- messageSends: ["removeAll"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeKey:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (aKey,aBlock){
- var self=this;
- 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},
- args: ["aKey", "aBlock"],
- source: "removeKey: aKey ifAbsent: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "values",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@values"];
- return $1;
- },
- args: [],
- source: "values\x0a\x09^ values",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "valuesDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self["@values"])._do_(aBlock);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"valuesDo:",{aBlock:aBlock},globals.Dictionary)})},
- args: ["aBlock"],
- source: "valuesDo: aBlock\x0a\x09^ values do: aBlock",
- messageSends: ["do:"],
- referencedClasses: []
- }),
- globals.Dictionary);
- smalltalk.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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsent:",
- protocol: 'accessing',
- fn: function (aKey,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._includesKey_(aKey);
- if(smalltalk.assert($2)){
- $1=self._basicAt_(aKey);
- } else {
- $1=_st(aBlock)._value();
- };
- return $1;
- }, 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 ]",
- messageSends: ["ifTrue:ifFalse:", "includesKey:", "basicAt:", "value"],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:put:",
- protocol: 'accessing',
- fn: function (aKey,aValue){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._basicAt_put_(aKey,aValue);
- return $1;
- }, 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",
- messageSends: ["basicAt:put:"],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includesKey:",
- protocol: 'testing',
- fn: function (aKey){
- var self=this;
- return self.hasOwnProperty(aKey);
- return self},
- args: ["aKey"],
- source: "includesKey: aKey\x0a\x09<return self.hasOwnProperty(aKey)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keys",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return Object.keys(self);
- return self},
- args: [],
- source: "keys\x0a\x09<return Object.keys(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "keysDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(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",
- messageSends: ["do:", "keys"],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeKey:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (aKey,aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_ifPresent_ifAbsent_(aKey,(function(removed){
- return smalltalk.withContext(function($ctx2) {
- self._basicDelete_(aKey);
- return removed;
- }, function($ctx2) {$ctx2.fillBlock({removed:removed},$ctx1,1)})}),(function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(aBlock)._value();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- return $1;
- }, 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 ]",
- messageSends: ["at:ifPresent:ifAbsent:", "basicDelete:", "value"],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "values",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return self._keys().map(function(key){
- return self._at_(key);
- });
- ;
- return self},
- args: [],
- source: "values\x0a\x09<\x0a\x09\x09return self._keys().map(function(key){\x0a\x09\x09\x09return self._at_(key);\x0a\x09\x09});\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "valuesDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(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",
- messageSends: ["do:", "values"],
- referencedClasses: []
- }),
- globals.HashedCollection);
- smalltalk.addClass('SequenceableCollection', globals.IndexableCollection, [], 'Kernel-Collections');
- globals.SequenceableCollection.comment="I am an IndexableCollection\x0awith numeric indexes starting with 1.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "=",
- protocol: 'comparing',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $3,$2,$4,$1,$5;
- var $early={};
- try {
- $3=self._class();
- $ctx1.sendIdx["class"]=1;
- $2=_st($3).__eq(_st(aCollection)._class());
- $ctx1.sendIdx["="]=1;
- $1=_st($2)._and_((function(){
- return smalltalk.withContext(function($ctx2) {
- $4=self._size();
- $ctx2.sendIdx["size"]=1;
- return _st($4).__eq(_st(aCollection)._size());
- $ctx2.sendIdx["="]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- if(! smalltalk.assert($1)){
- return false;
- };
- self._withIndexDo_((function(each,i){
- return smalltalk.withContext(function($ctx2) {
- $5=_st(_st(aCollection)._at_(i)).__eq(each);
- if(! smalltalk.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",
- messageSends: ["ifFalse:", "and:", "=", "class", "size", "withIndexDo:", "at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "addLast:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["add:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "allButFirst",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._copyFrom_to_((2),self._size());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"allButFirst",{},globals.SequenceableCollection)})},
- args: [],
- source: "allButFirst\x0a\x09^ self copyFrom: 2 to: self size",
- messageSends: ["copyFrom:to:", "size"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "allButLast",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._copyFrom_to_((1),_st(self._size()).__minus((1)));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"allButLast",{},globals.SequenceableCollection)})},
- args: [],
- source: "allButLast\x0a\x09^ self copyFrom: 1 to: self size - 1",
- messageSends: ["copyFrom:to:", "-", "size"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "atRandom",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_(_st(self._size())._atRandom());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"atRandom",{},globals.SequenceableCollection)})},
- args: [],
- source: "atRandom\x0a\x09^ self at: self size atRandom",
- messageSends: ["at:", "atRandom", "size"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "beginsWith:",
- protocol: 'testing',
- fn: function (prefix){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1,$4;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=_st(prefix)._size();
- $ctx1.sendIdx["size"]=2;
- $1=_st($2).__lt($3);
- if(smalltalk.assert($1)){
- return false;
- };
- $4=_st(self._first_(_st(prefix)._size())).__eq(prefix);
- return $4;
- }, 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",
- messageSends: ["ifTrue:", "<", "size", "=", "first:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "copyFrom:to:",
- protocol: 'copying',
- fn: function (anIndex,anotherIndex){
- var self=this;
- var range,newCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- range=_st(anIndex)._to_(anotherIndex);
- newCollection=_st(self._class())._new_(_st(range)._size());
- _st(range)._withIndexDo_((function(each,i){
- return smalltalk.withContext(function($ctx2) {
- return _st(newCollection)._at_put_(i,self._at_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1,1)})}));
- $1=newCollection;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex,range:range,newCollection:newCollection},globals.SequenceableCollection)})},
- args: ["anIndex", "anotherIndex"],
- source: "copyFrom: anIndex to: anotherIndex\x0a\x09| range newCollection |\x0a\x09range := anIndex to: anotherIndex.\x0a\x09newCollection := self class new: range size.\x0a\x09range withIndexDo: [ :each :i |\x0a\x09\x09newCollection at: i put: (self at: each) ].\x0a\x09^ newCollection",
- messageSends: ["to:", "new:", "class", "size", "withIndexDo:", "at:put:", "at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "deepCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- var newCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- newCollection=_st(self._class())._new_(self._size());
- self._withIndexDo_((function(each,index){
- return smalltalk.withContext(function($ctx2) {
- return _st(newCollection)._at_put_(index,_st(each)._deepCopy());
- }, function($ctx2) {$ctx2.fillBlock({each:each,index:index},$ctx1,1)})}));
- $1=newCollection;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{newCollection:newCollection},globals.SequenceableCollection)})},
- args: [],
- source: "deepCopy\x0a\x09| newCollection |\x0a\x09newCollection := self class new: self size.\x0a\x09self withIndexDo: [ :each :index |\x0a\x09\x09newCollection at: index put: each deepCopy ].\x0a\x09^ newCollection",
- messageSends: ["new:", "class", "size", "withIndexDo:", "at:put:", "deepCopy"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "detect:ifNone:",
- protocol: 'enumerating',
- fn: function (aBlock,anotherBlock){
- var self=this;
- self = self._numericallyIndexable();
- for(var i = 0; i < self.length; i++)
- if(aBlock._value_(self[i]))
- return self[i];
- return anotherBlock._value();
- ;
- return self},
- args: ["aBlock", "anotherBlock"],
- source: "detect: aBlock ifNone: anotherBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- aBlock._value_(self[i]);
- }
- ;
- return self},
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "endsWith:",
- protocol: 'testing',
- fn: function (suffix){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1,$4;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=_st(suffix)._size();
- $ctx1.sendIdx["size"]=2;
- $1=_st($2).__lt($3);
- if(smalltalk.assert($1)){
- return false;
- };
- $4=_st(self._last_(_st(suffix)._size())).__eq(suffix);
- return $4;
- }, 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",
- messageSends: ["ifTrue:", "<", "size", "=", "last:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "first",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_((1));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"first",{},globals.SequenceableCollection)})},
- args: [],
- source: "first\x0a\x09^ self at: 1",
- messageSends: ["at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "first:",
- protocol: 'accessing',
- fn: function (aNumber){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- $1=_st(self._size()).__lt(aNumber);
- if(smalltalk.assert($1)){
- self._error_("Invalid number of elements");
- };
- $2=self._copyFrom_to_((1),aNumber);
- return $2;
- }, 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",
- messageSends: ["ifTrue:", "<", "size", "error:", "copyFrom:to:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fourth",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_((4));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"fourth",{},globals.SequenceableCollection)})},
- args: [],
- source: "fourth\x0a\x09^ self at: 4",
- messageSends: ["at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includes:",
- protocol: 'testing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._indexOf_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return nil;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})})))._notNil();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},globals.SequenceableCollection)})},
- args: ["anObject"],
- source: "includes: anObject\x0a\x09^ (self indexOf: anObject ifAbsent: [ nil ]) notNil",
- messageSends: ["notNil", "indexOf:ifAbsent:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,aBlock){
- var self=this;
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- if(_st(self[i]).__eq(anObject)) {return i+1}
- };
- return aBlock._value();
- ;
- return self},
- args: ["anObject", "aBlock"],
- source: "indexOf: anObject ifAbsent: aBlock\x0a\x09<\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=0; i < self.length; i++) {\x0a\x09\x09\x09if(_st(self[i]).__eq(anObject)) {return i+1}\x0a\x09\x09};\x0a\x09\x09return aBlock._value();\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:startingAt:",
- protocol: 'accessing',
- fn: function (anObject,start){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._indexOf_startingAt_ifAbsent_(anObject,start,(function(){
- return smalltalk.withContext(function($ctx2) {
- return (0);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, 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 ]",
- messageSends: ["indexOf:startingAt:ifAbsent:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "indexOf:startingAt:ifAbsent:",
- protocol: 'accessing',
- fn: function (anObject,start,aBlock){
- var self=this;
- self = self._numericallyIndexable();
- for(var i=start - 1; i < self.length; i++){
- if(_st(self[i]).__eq(anObject)) {return i+1}
- }
- return aBlock._value();
- ;
- return self},
- args: ["anObject", "start", "aBlock"],
- source: "indexOf: anObject startingAt: start ifAbsent: aBlock\x0a\x09<\x0a\x09\x09self = self._numericallyIndexable();\x0a\x09\x09for(var i=start - 1; i < self.length; i++){\x0a\x09\x09\x09if(_st(self[i]).__eq(anObject)) {return i+1}\x0a\x09\x09}\x0a\x09\x09return aBlock._value();\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "last",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_(self._size());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"last",{},globals.SequenceableCollection)})},
- args: [],
- source: "last\x0a\x09^ self at: self size",
- messageSends: ["at:", "size"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "last:",
- protocol: 'accessing',
- fn: function (aNumber){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$6,$5,$4,$3;
- $2=self._size();
- $ctx1.sendIdx["size"]=1;
- $1=_st($2).__lt(aNumber);
- if(smalltalk.assert($1)){
- self._error_("Invalid number of elements");
- };
- $6=self._size();
- $ctx1.sendIdx["size"]=2;
- $5=_st($6).__minus(aNumber);
- $4=_st($5).__plus((1));
- $3=self._copyFrom_to_($4,self._size());
- return $3;
- }, 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",
- messageSends: ["ifTrue:", "<", "size", "error:", "copyFrom:to:", "+", "-"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "newStream",
- protocol: 'streaming',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._streamClass())._on_(self);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"newStream",{},globals.SequenceableCollection)})},
- args: [],
- source: "newStream\x0a\x09^ self streamClass on: self",
- messageSends: ["on:", "streamClass"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "numericallyIndexable",
- protocol: 'private',
- fn: function (){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "readStream",
- protocol: 'streaming',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._stream();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"readStream",{},globals.SequenceableCollection)})},
- args: [],
- source: "readStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^ self stream",
- messageSends: ["stream"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeLast",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._remove_(self._last());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"removeLast",{},globals.SequenceableCollection)})},
- args: [],
- source: "removeLast\x0a\x09^ self remove: self last",
- messageSends: ["remove:", "last"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "reversed",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._subclassResponsibility();
- return self}, function($ctx1) {$ctx1.fill(self,"reversed",{},globals.SequenceableCollection)})},
- args: [],
- source: "reversed\x0a\x09self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "second",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_((2));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"second",{},globals.SequenceableCollection)})},
- args: [],
- source: "second\x0a\x09^ self at: 2",
- messageSends: ["at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "shallowCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- var newCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- newCollection=_st(self._class())._new_(self._size());
- self._withIndexDo_((function(each,index){
- return smalltalk.withContext(function($ctx2) {
- return _st(newCollection)._at_put_(index,each);
- }, function($ctx2) {$ctx2.fillBlock({each:each,index:index},$ctx1,1)})}));
- $1=newCollection;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{newCollection:newCollection},globals.SequenceableCollection)})},
- args: [],
- source: "shallowCopy\x0a\x09| newCollection |\x0a\x09newCollection := self class new: self size.\x0a\x09self withIndexDo: [ :each :index |\x0a\x09\x09newCollection at: index put: each ].\x0a\x09^ newCollection",
- messageSends: ["new:", "class", "size", "withIndexDo:", "at:put:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "stream",
- protocol: 'streaming',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._newStream();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"stream",{},globals.SequenceableCollection)})},
- args: [],
- source: "stream\x0a\x09^ self newStream",
- messageSends: ["newStream"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "streamClass",
- protocol: 'streaming',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._class())._streamClass();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"streamClass",{},globals.SequenceableCollection)})},
- args: [],
- source: "streamClass\x0a\x09^ self class streamClass",
- messageSends: ["streamClass", "class"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "third",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._at_((3));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"third",{},globals.SequenceableCollection)})},
- args: [],
- source: "third\x0a\x09^ self at: 3",
- messageSends: ["at:"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:do:",
- protocol: 'enumerating',
- fn: function (anotherCollection,aBlock){
- var self=this;
- self = self._numericallyIndexable();
- anotherCollection = anotherCollection._numericallyIndexable();
- for(var i=0; i<self.length; i++) {
- aBlock._value_value_(self[i], anotherCollection[i]);
- }
- ;
- return self},
- args: ["anotherCollection", "aBlock"],
- source: "with: anotherCollection do: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "withIndexDo:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- self = self._numericallyIndexable();
- for(var i=0; i < self.length; i++) {
- aBlock._value_value_(self[i], i+1);
- }
- ;
- return self},
- args: ["aBlock"],
- source: "withIndexDo: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "writeStream",
- protocol: 'streaming',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._stream();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"writeStream",{},globals.SequenceableCollection)})},
- args: [],
- source: "writeStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^ self stream",
- messageSends: ["stream"],
- referencedClasses: []
- }),
- globals.SequenceableCollection);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "streamClass",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- function $Stream(){return globals.Stream||(typeof Stream=="undefined"?nil:Stream)}
- return $Stream();
- },
- args: [],
- source: "streamClass\x0a\x09\x09^ Stream",
- messageSends: [],
- referencedClasses: ["Stream"]
- }),
- globals.SequenceableCollection.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "streamContents:",
- protocol: 'streaming',
- fn: function (aBlock){
- var self=this;
- var stream;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- stream=_st(self._streamClass())._on_(self._new());
- _st(aBlock)._value_(stream);
- $1=_st(stream)._contents();
- return $1;
- }, 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",
- messageSends: ["on:", "streamClass", "new", "value:", "contents"],
- referencedClasses: []
- }),
- globals.SequenceableCollection.klass);
- smalltalk.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`.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- self.push(anObject); return anObject;;
- return self},
- args: ["anObject"],
- source: "add: anObject\x0a\x09<self.push(anObject); return anObject;>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "addFirst:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- self.unshift(anObject); return anObject;;
- return self},
- args: ["anObject"],
- source: "addFirst: anObject\x0a\x09<self.unshift(anObject); return anObject;>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asJavascript",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st("[".__comma(_st(self._collect_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each)._asJavascript();
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})})))._join_(", "))).__comma("]");
- $ctx1.sendIdx[","]=1;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},globals.Array)})},
- args: [],
- source: "asJavascript\x0a\x09^ '[', ((self collect: [:each | each asJavascript ]) join: ', '), ']'",
- messageSends: [",", "join:", "collect:", "asJavascript"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock){
- var self=this;
- return anIndex >= 1 && anIndex <= self.length
- ? self[anIndex - 1]
- : aBlock._value()
- ;
- return self},
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifAbsent: aBlock\x0a\x09<\x0a\x09\x09return anIndex >>= 1 && anIndex <= self.length\x0a\x09\x09\x09? self[anIndex - 1]\x0a\x09\x09\x09: aBlock._value()\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- return anIndex >= 1 && anIndex <= self.length
- ? aBlock._value_(self[anIndex - 1])
- : anotherBlock._value()
- ;
- return self},
- args: ["anIndex", "aBlock", "anotherBlock"],
- source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:put:",
- protocol: 'accessing',
- fn: function (anIndex,anObject){
- var self=this;
- return self[anIndex - 1] = anObject;
- return self},
- args: ["anIndex", "anObject"],
- source: "at: anIndex put: anObject\x0a\x09<return self[anIndex - 1] = anObject>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "collect:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return self.map(function(each) {return aBlock._value_(each)});
- return self},
- args: ["aBlock"],
- source: "collect: aBlock\x0a\x09\x22Optimized version\x22\x0a\x09\x0a\x09<return self.map(function(each) {return aBlock._value_(each)})>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "join:",
- protocol: 'enumerating',
- fn: function (aString){
- var self=this;
- return self.join(aString);
- return self},
- args: ["aString"],
- source: "join: aString\x0a\x09<return self.join(aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "numericallyIndexable",
- protocol: 'private',
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "numericallyIndexable\x0a\x09^ self",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.Array.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]);
- $ctx1.sendIdx["printOn:"]=1;
- _st(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._do_separatedBy_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}),(function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(aStream)._nextPutAll_(" ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- _st(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: ')'",
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (anObject,aBlock){
- var self=this;
- var index;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- index=self._indexOf_ifAbsent_(anObject,(function(){
- return smalltalk.withContext(function($ctx2) {
- return (0);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- $2=_st(index).__eq((0));
- if(smalltalk.assert($2)){
- $1=_st(aBlock)._value();
- } else {
- self._removeIndex_(index);
- $1=anObject;
- };
- return $1;
- }, 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 ]",
- messageSends: ["indexOf:ifAbsent:", "ifFalse:ifTrue:", "=", "removeIndex:", "value"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- self.length = 0;
- return self},
- args: [],
- source: "removeAll\x0a\x09<self.length = 0>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeFrom:to:",
- protocol: 'adding/removing',
- fn: function (aNumber,anotherNumber){
- var self=this;
- self.splice(aNumber -1, anotherNumber - aNumber + 1);
- return self},
- args: ["aNumber", "anotherNumber"],
- source: "removeFrom: aNumber to: anotherNumber\x0a\x09<self.splice(aNumber -1, anotherNumber - aNumber + 1)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeIndex:",
- protocol: 'adding/removing',
- fn: function (anInteger){
- var self=this;
- self.splice(anInteger - 1, 1);
- return self},
- args: ["anInteger"],
- source: "removeIndex: anInteger\x0a\x09<self.splice(anInteger - 1, 1)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeLast",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- return self.pop();;
- return self},
- args: [],
- source: "removeLast\x0a\x09<return self.pop();>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "reversed",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self._copy().reverse();
- return self},
- args: [],
- source: "reversed\x0a\x09<return self._copy().reverse()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "select:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var result = self.klass._new();
- for(var i=0; i<self.length; i++) {
- if(aBlock._value_(self[i])) {
- result.push(self[i]);
- }
- }
- return result;
- ;
- return self},
- args: ["aBlock"],
- source: "select: aBlock\x0a\x09\x22Optimized version\x22\x0a\x09\x0a\x09<\x0a\x09\x09var result = self.klass._new();\x0a\x09\x09for(var i=0; i<self.length; i++) {\x0a\x09\x09\x09if(aBlock._value_(self[i])) {\x0a\x09\x09\x09\x09result.push(self[i]);\x0a\x09\x09\x09}\x0a\x09\x09}\x0a\x09\x09return result;\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return self.length;
- return self},
- args: [],
- source: "size\x0a\x09<return self.length>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "sort",
- protocol: 'enumerating',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._basicPerform_("sort");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"sort",{},globals.Array)})},
- args: [],
- source: "sort\x0a\x09^ self basicPerform: 'sort'",
- messageSends: ["basicPerform:"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "sort:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return self.sort(function(a, b) {
- if(aBlock._value_value_(a,b)) {return -1} else {return 1}
- })
- ;
- return self},
- args: ["aBlock"],
- source: "sort: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "sorted",
- protocol: 'enumerating',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._copy())._sort();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"sorted",{},globals.Array)})},
- args: [],
- source: "sorted\x0a\x09^ self copy sort",
- messageSends: ["sort", "copy"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "sorted:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._copy())._sort_(aBlock);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"sorted:",{aBlock:aBlock},globals.Array)})},
- args: ["aBlock"],
- source: "sorted: aBlock\x0a\x09^ self copy sort: aBlock",
- messageSends: ["sort:", "copy"],
- referencedClasses: []
- }),
- globals.Array);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "new:",
- protocol: 'instance creation',
- fn: function (anInteger){
- var self=this;
- return new Array(anInteger);
- return self},
- args: ["anInteger"],
- source: "new: anInteger\x0a\x09<return new Array(anInteger)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Array.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:",
- protocol: 'instance creation',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new_((1));
- _st($2)._at_put_((1),anObject);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["at:put:", "new:", "yourself"],
- referencedClasses: []
- }),
- globals.Array.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:with:",
- protocol: 'instance creation',
- fn: function (anObject,anObject2){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new_((2));
- _st($2)._at_put_((1),anObject);
- $ctx1.sendIdx["at:put:"]=1;
- _st($2)._at_put_((2),anObject2);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["at:put:", "new:", "yourself"],
- referencedClasses: []
- }),
- globals.Array.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "with:with:with:",
- protocol: 'instance creation',
- fn: function (anObject,anObject2,anObject3){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new_((3));
- _st($2)._at_put_((1),anObject);
- $ctx1.sendIdx["at:put:"]=1;
- _st($2)._at_put_((2),anObject2);
- $ctx1.sendIdx["at:put:"]=2;
- _st($2)._at_put_((3),anObject3);
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["at:put:", "new:", "yourself"],
- referencedClasses: []
- }),
- globals.Array.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "withAll:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- var instance,index;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- index=(1);
- instance=self._new_(_st(aCollection)._size());
- _st(aCollection)._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- _st(instance)._at_put_(index,each);
- index=_st(index).__plus((1));
- return index;
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=instance;
- return $1;
- }, 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",
- messageSends: ["new:", "size", "do:", "at:put:", "+"],
- referencedClasses: []
- }),
- globals.Array.klass);
- smalltalk.addClass('CharacterArray', globals.SequenceableCollection, [], 'Kernel-Collections');
- globals.CharacterArray.comment="I am the abstract superclass of string-like collections.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: ",",
- protocol: 'copying',
- fn: function (aString){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._asString();
- $ctx1.sendIdx["asString"]=1;
- $1=_st($2).__comma(_st(aString)._asString());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,",",{aString:aString},globals.CharacterArray)})},
- args: ["aString"],
- source: ", aString\x0a\x09^ self asString, aString asString",
- messageSends: [",", "asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["errorReadOnly"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asLowercase",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._class())._fromString_(_st(self._asString())._asLowercase());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asLowercase",{},globals.CharacterArray)})},
- args: [],
- source: "asLowercase\x0a\x09^ self class fromString: self asString asLowercase",
- messageSends: ["fromString:", "class", "asLowercase", "asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asNumber",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._asString())._asNumber();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asNumber",{},globals.CharacterArray)})},
- args: [],
- source: "asNumber\x0a\x09^ self asString asNumber",
- messageSends: ["asNumber", "asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asString",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._subclassResponsibility();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asString",{},globals.CharacterArray)})},
- args: [],
- source: "asString\x0a\x09^ self subclassResponsibility",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asSymbol",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._asString();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asSymbol",{},globals.CharacterArray)})},
- args: [],
- source: "asSymbol\x0a\x09^ self asString",
- messageSends: ["asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asUppercase",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._class())._fromString_(_st(self._asString())._asUppercase());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asUppercase",{},globals.CharacterArray)})},
- args: [],
- source: "asUppercase\x0a\x09^ self class fromString: self asString asUppercase",
- messageSends: ["fromString:", "class", "asUppercase", "asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:put:",
- protocol: 'accessing',
- fn: function (anIndex,anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["errorReadOnly"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "errorReadOnly",
- protocol: 'error handling',
- fn: function (){
- var self=this;
- return smalltalk.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'",
- messageSends: ["error:"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(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",
- messageSends: ["printOn:", "asString"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "putOn:",
- protocol: 'streaming',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(aStream)._nextPutString_(self);
- return self}, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},globals.CharacterArray)})},
- args: ["aStream"],
- source: "putOn: aStream\x0a\x09aStream nextPutString: self",
- messageSends: ["nextPutString:"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- return smalltalk.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",
- messageSends: ["errorReadOnly"],
- referencedClasses: []
- }),
- globals.CharacterArray);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromString:",
- protocol: 'instance creation',
- fn: function (aString){
- var self=this;
- return smalltalk.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",
- messageSends: ["subclassResponsibility"],
- referencedClasses: []
- }),
- globals.CharacterArray.klass);
- smalltalk.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 >> #,`";
- smalltalk.addMethod(
- smalltalk.method({
- selector: ",",
- protocol: 'copying',
- fn: function (aString){
- var self=this;
- return String(self) + aString;
- return self},
- args: ["aString"],
- source: ", aString\x0a\x09<return String(self) + aString>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "<",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return String(self) < aString._asString();
- return self},
- args: ["aString"],
- source: "< aString\x0a\x09<return String(self) < aString._asString()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "<=",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return String(self) <= aString._asString();
- return self},
- args: ["aString"],
- source: "<= aString\x0a\x09<return String(self) <= aString._asString()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "=",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return aString != null &&
- typeof aString._isString === "function" &&
- aString._isString() &&
- String(self) === String(aString)
- ;
- return self},
- args: ["aString"],
- source: "= aString\x0a\x09<\x0a\x09\x09return aString != null &&\x0a\x09\x09\x09typeof aString._isString === \x22function\x22 &&\x0a\x09\x09\x09aString._isString() &&\x0a\x09\x09\x09String(self) === String(aString)\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "==",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self.__eq(aString);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"==",{aString:aString},globals.String)})},
- args: ["aString"],
- source: "== aString\x0a\x09^ self = aString",
- messageSends: ["="],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: ">",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return String(self) > aString._asString();
- return self},
- args: ["aString"],
- source: "> aString\x0a\x09<return String(self) >> aString._asString()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: ">=",
- protocol: 'comparing',
- fn: function (aString){
- var self=this;
- return String(self) >= aString._asString();
- return self},
- args: ["aString"],
- source: ">= aString\x0a\x09<return String(self) >>= aString._asString()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asJSON",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asJSON\x0a\x09^ self",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asJavascript",
- protocol: 'converting',
- fn: function (){
- var self=this;
- 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},
- args: [],
- source: "asJavascript\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asLowercase",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self.toLowerCase();
- return self},
- args: [],
- source: "asLowercase\x0a\x09<return self.toLowerCase()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asMutator",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- $1=_st(self._last()).__eq(":");
- if(! smalltalk.assert($1)){
- $2=self.__comma(":");
- return $2;
- };
- 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",
- messageSends: ["ifFalse:", "=", "last", ","],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asNumber",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return Number(self);
- return self},
- args: [],
- source: "asNumber\x0a\x09<return Number(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asRegexp",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $RegularExpression(){return globals.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($RegularExpression())._fromString_(self);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"asRegexp",{},globals.String)})},
- args: [],
- source: "asRegexp\x0a\x09^ RegularExpression fromString: self",
- messageSends: ["fromString:"],
- referencedClasses: ["RegularExpression"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asSelector",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.selector(self);
- return self},
- args: [],
- source: "asSelector\x0a\x09<return smalltalk.selector(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asString",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asString\x0a\x09^ self",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asSymbol",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self;
- },
- args: [],
- source: "asSymbol\x0a\x09^ self",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asUppercase",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self.toUpperCase();
- return self},
- args: [],
- source: "asUppercase\x0a\x09<return self.toUpperCase()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "asciiValue",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return self.charCodeAt(0);;
- return self},
- args: [],
- source: "asciiValue\x0a\x09<return self.charCodeAt(0);>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock){
- var self=this;
- return String(self)[anIndex - 1] || aBlock._value();
- return self},
- args: ["anIndex", "aBlock"],
- source: "at: anIndex ifAbsent: aBlock\x0a\x09<return String(self)[anIndex - 1] || aBlock._value()>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "at:ifPresent:ifAbsent:",
- protocol: 'accessing',
- fn: function (anIndex,aBlock,anotherBlock){
- var self=this;
- var result = String(self)[anIndex - 1];
- return result ? aBlock._value_(result) : anotherBlock._value();
- ;
- return self},
- args: ["anIndex", "aBlock", "anotherBlock"],
- source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09<\x0a\x09\x09var result = String(self)[anIndex - 1];\x0a\x09\x09return result ? aBlock._value_(result) : anotherBlock._value();\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "capitalized",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._isEmpty();
- if(smalltalk.assert($2)){
- $1=self;
- } else {
- $1=_st(_st(self._first())._asUppercase()).__comma(self._allButFirst());
- };
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"capitalized",{},globals.String)})},
- args: [],
- source: "capitalized\x0a\x09^ self isEmpty\x0a\x09\x09ifTrue: [ self ]\x0a\x09\x09ifFalse: [ self first asUppercase, self allButFirst ]",
- messageSends: ["ifTrue:ifFalse:", "isEmpty", ",", "asUppercase", "first", "allButFirst"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "charCodeAt:",
- protocol: 'accessing',
- fn: function (anInteger){
- var self=this;
- return self.charCodeAt(anInteger - 1);
- return self},
- args: ["anInteger"],
- source: "charCodeAt: anInteger\x0a\x09<return self.charCodeAt(anInteger - 1)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "copyFrom:to:",
- protocol: 'copying',
- fn: function (anIndex,anotherIndex){
- var self=this;
- return self.substring(anIndex - 1, anotherIndex);
- return self},
- args: ["anIndex", "anotherIndex"],
- source: "copyFrom: anIndex to: anotherIndex\x0a\x09<return self.substring(anIndex - 1, anotherIndex)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "crlfSanitized",
- protocol: 'converting',
- fn: function (){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._lines())._join_(_st($String())._lf());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"crlfSanitized",{},globals.String)})},
- args: [],
- source: "crlfSanitized\x0a\x09^ self lines join: String lf",
- messageSends: ["join:", "lines", "lf"],
- referencedClasses: ["String"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "deepCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._shallowCopy();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},globals.String)})},
- args: [],
- source: "deepCopy\x0a\x09^ self shallowCopy",
- messageSends: ["shallowCopy"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "escaped",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return escape(self);
- return self},
- args: [],
- source: "escaped\x0a\x09<return escape(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "identityHash",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self.__comma("s");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"identityHash",{},globals.String)})},
- args: [],
- source: "identityHash\x0a\x09^ self, 's'",
- messageSends: [","],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includesSubString:",
- protocol: 'testing',
- fn: function (subString){
- var self=this;
- return self.indexOf(subString) != -1;
- return self},
- args: ["subString"],
- source: "includesSubString: subString\x0a\x09<return self.indexOf(subString) != -1>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isCapitalized",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=self._first();
- $ctx1.sendIdx["first"]=1;
- $2=_st($3)._asUppercase();
- $1=_st($2).__eq_eq(self._first());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"isCapitalized",{},globals.String)})},
- args: [],
- source: "isCapitalized\x0a\x09^ self first asUppercase == self first",
- messageSends: ["==", "asUppercase", "first"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isImmutable",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isImmutable\x0a\x09^ true",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isString",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return true;
- },
- args: [],
- source: "isString\x0a\x09^ true",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isVowel",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(_st(self._size()).__eq((1)))._and_((function(){
- return smalltalk.withContext(function($ctx2) {
- return "aeiou"._includes_(self._asLowercase());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $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 ]",
- messageSends: ["and:", "=", "size", "includes:", "asLowercase"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "join:",
- protocol: 'split join',
- fn: function (aCollection){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($String())._streamContents_((function(stream){
- return smalltalk.withContext(function($ctx2) {
- return _st(aCollection)._do_separatedBy_((function(each){
- return smalltalk.withContext(function($ctx3) {
- return _st(stream)._nextPutAll_(_st(each)._asString());
- $ctx3.sendIdx["nextPutAll:"]=1;
- }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2,2)})}),(function(){
- return smalltalk.withContext(function($ctx3) {
- return _st(stream)._nextPutAll_(self);
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)})}));
- }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1,1)})}));
- return $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 ]]",
- messageSends: ["streamContents:", "do:separatedBy:", "nextPutAll:", "asString"],
- referencedClasses: ["String"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "lineIndicesDo:",
- protocol: 'split join',
- fn: function (aBlock){
- var self=this;
- var cr,lf,start,sz,nextLF,nextCR;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$4,$5,$3,$6,$7,$9,$8,$10,$11;
- var $early={};
- try {
- start=(1);
- sz=self._size();
- cr=_st($String())._cr();
- nextCR=self._indexOf_startingAt_(cr,(1));
- $ctx1.sendIdx["indexOf:startingAt:"]=1;
- lf=_st($String())._lf();
- nextLF=self._indexOf_startingAt_(lf,(1));
- $ctx1.sendIdx["indexOf:startingAt:"]=2;
- _st((function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(start).__lt_eq(sz);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}))._whileTrue_((function(){
- return smalltalk.withContext(function($ctx2) {
- $2=_st(nextLF).__eq((0));
- $ctx2.sendIdx["="]=1;
- $1=_st($2)._and_((function(){
- return smalltalk.withContext(function($ctx3) {
- return _st(nextCR).__eq((0));
- $ctx3.sendIdx["="]=2;
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,3)})}));
- $ctx2.sendIdx["and:"]=1;
- if(smalltalk.assert($1)){
- _st(aBlock)._value_value_value_(start,sz,sz);
- $ctx2.sendIdx["value:value:value:"]=1;
- throw $early=[self];
- };
- $4=_st(nextCR).__eq((0));
- $ctx2.sendIdx["="]=3;
- $3=_st($4)._or_((function(){
- return smalltalk.withContext(function($ctx3) {
- $5=(0).__lt(nextLF);
- $ctx3.sendIdx["<"]=1;
- return _st($5)._and_((function(){
- return smalltalk.withContext(function($ctx4) {
- return _st(nextLF).__lt(nextCR);
- }, function($ctx4) {$ctx4.fillBlock({},$ctx3,6)})}));
- }, function($ctx3) {$ctx3.fillBlock({},$ctx2,5)})}));
- if(smalltalk.assert($3)){
- $6=start;
- $7=_st(nextLF).__minus((1));
- $ctx2.sendIdx["-"]=1;
- _st(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=_st($9).__eq(nextLF);
- if(smalltalk.assert($8)){
- $10=start;
- $11=_st(nextCR).__minus((1));
- $ctx2.sendIdx["-"]=2;
- _st(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 {
- _st(aBlock)._value_value_value_(start,_st(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 ] ]]",
- messageSends: ["size", "cr", "indexOf:startingAt:", "lf", "whileTrue:", "<=", "ifTrue:", "and:", "=", "value:value:value:", "ifTrue:ifFalse:", "or:", "<", "-", "+"],
- referencedClasses: ["String"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "lineNumber:",
- protocol: 'split join',
- fn: function (anIndex){
- var self=this;
- var lineCount;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$3;
- var $early={};
- try {
- lineCount=(0);
- self._lineIndicesDo_((function(start,endWithoutDelimiters,end){
- return smalltalk.withContext(function($ctx2) {
- lineCount=_st(lineCount).__plus((1));
- $2=lineCount;
- $1=_st($2).__eq(anIndex);
- if(smalltalk.assert($1)){
- $3=self._copyFrom_to_(start,endWithoutDelimiters);
- throw $early=[$3];
- };
- }, 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",
- messageSends: ["lineIndicesDo:", "ifTrue:", "=", "+", "copyFrom:to:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "lines",
- protocol: 'split join',
- fn: function (){
- var self=this;
- var lines;
- function $Array(){return globals.Array||(typeof Array=="undefined"?nil:Array)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- lines=_st($Array())._new();
- self._linesDo_((function(aLine){
- return smalltalk.withContext(function($ctx2) {
- return _st(lines)._add_(aLine);
- }, function($ctx2) {$ctx2.fillBlock({aLine:aLine},$ctx1,1)})}));
- $1=lines;
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"lines",{lines:lines},globals.String)})},
- args: [],
- source: "lines\x0a\x09\x22Answer an array of lines composing this receiver without the line ending delimiters.\x22\x0a\x0a\x09| lines |\x0a\x09lines := Array new.\x0a\x09self linesDo: [ :aLine | lines add: aLine ].\x0a\x09^ lines",
- messageSends: ["new", "linesDo:", "add:"],
- referencedClasses: ["Array"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "linesDo:",
- protocol: 'split join',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._lineIndicesDo_((function(start,endWithoutDelimiters,end){
- return smalltalk.withContext(function($ctx2) {
- return _st(aBlock)._value_(self._copyFrom_to_(start,endWithoutDelimiters));
- }, function($ctx2) {$ctx2.fillBlock({start:start,endWithoutDelimiters:endWithoutDelimiters,end:end},$ctx1,1)})}));
- 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 lineIndicesDo: [ :start :endWithoutDelimiters :end |\x0a\x09\x09aBlock value: (self copyFrom: start to: endWithoutDelimiters) ]",
- messageSends: ["lineIndicesDo:", "value:", "copyFrom:to:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "match:",
- protocol: 'regular expressions',
- fn: function (aRegexp){
- var self=this;
- return self.search(aRegexp) != -1;
- return self},
- args: ["aRegexp"],
- source: "match: aRegexp\x0a\x09<return self.search(aRegexp) != -1>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "matchesOf:",
- protocol: 'regular expressions',
- fn: function (aRegularExpression){
- var self=this;
- return self.match(aRegularExpression);
- return self},
- args: ["aRegularExpression"],
- source: "matchesOf: aRegularExpression\x0a\x09<return self.match(aRegularExpression)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "numericallyIndexable",
- protocol: 'private',
- fn: function (){
- var self=this;
- return String(self);
- return self},
- args: [],
- source: "numericallyIndexable\x0a\x09<return String(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printNl",
- protocol: 'printing',
- fn: function (){
- var self=this;
- console.log(self);
- return self},
- args: [],
- source: "printNl\x0a\x09<console.log(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- _st(aStream)._nextPutAll_("'");
- $ctx1.sendIdx["nextPutAll:"]=1;
- _st(aStream)._nextPutAll_(self);
- $ctx1.sendIdx["nextPutAll:"]=2;
- $1=_st(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;\x0a\x09\x09nextPutAll: ''''",
- messageSends: ["nextPutAll:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "replace:with:",
- protocol: 'regular expressions',
- fn: function (aString,anotherString){
- var self=this;
- function $RegularExpression(){return globals.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._replaceRegexp_with_(_st($RegularExpression())._fromString_flag_(aString,"g"),anotherString);
- return $1;
- }, 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",
- messageSends: ["replaceRegexp:with:", "fromString:flag:"],
- referencedClasses: ["RegularExpression"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "replaceRegexp:with:",
- protocol: 'regular expressions',
- fn: function (aRegexp,aString){
- var self=this;
- return self.replace(aRegexp, aString);
- return self},
- args: ["aRegexp", "aString"],
- source: "replaceRegexp: aRegexp with: aString\x0a\x09<return self.replace(aRegexp, aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "reversed",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return self.split("").reverse().join("");
- return self},
- args: [],
- source: "reversed\x0a\x09<return self.split(\x22\x22).reverse().join(\x22\x22)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "shallowCopy",
- protocol: 'copying',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._class())._fromString_(self);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},globals.String)})},
- args: [],
- source: "shallowCopy\x0a\x09^ self class fromString: self",
- messageSends: ["fromString:", "class"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return self.length;
- return self},
- args: [],
- source: "size\x0a\x09<return self.length>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "subStrings:",
- protocol: 'split join',
- fn: function (aString){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._tokenize_(aString);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"subStrings:",{aString:aString},globals.String)})},
- args: ["aString"],
- source: "subStrings: aString\x0a\x09^ self tokenize: aString",
- messageSends: ["tokenize:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "tokenize:",
- protocol: 'split join',
- fn: function (aString){
- var self=this;
- return self.split(aString);
- return self},
- args: ["aString"],
- source: "tokenize: aString\x0a\x09<return self.split(aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimBoth",
- protocol: 'regular expressions',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._trimBoth_("\x5cs");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"trimBoth",{},globals.String)})},
- args: [],
- source: "trimBoth\x0a\x09^ self trimBoth: '\x5cs'",
- messageSends: ["trimBoth:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimBoth:",
- protocol: 'regular expressions',
- fn: function (separators){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._trimLeft_(separators))._trimRight_(separators);
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"trimBoth:",{separators:separators},globals.String)})},
- args: ["separators"],
- source: "trimBoth: separators\x0a\x09^ (self trimLeft: separators) trimRight: separators",
- messageSends: ["trimRight:", "trimLeft:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimLeft",
- protocol: 'regular expressions',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._trimLeft_("\x5cs");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"trimLeft",{},globals.String)})},
- args: [],
- source: "trimLeft\x0a\x09^ self trimLeft: '\x5cs'",
- messageSends: ["trimLeft:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimLeft:",
- protocol: 'regular expressions',
- fn: function (separators){
- var self=this;
- function $RegularExpression(){return globals.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)}
- return smalltalk.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=_st("^[".__comma(separators)).__comma("]+");
- $ctx1.sendIdx[","]=1;
- $2=_st($RegularExpression())._fromString_flag_($3,"g");
- $1=self._replaceRegexp_with_($2,"");
- return $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: ''",
- messageSends: ["replaceRegexp:with:", "fromString:flag:", ","],
- referencedClasses: ["RegularExpression"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimRight",
- protocol: 'regular expressions',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._trimRight_("\x5cs");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"trimRight",{},globals.String)})},
- args: [],
- source: "trimRight\x0a\x09^ self trimRight: '\x5cs'",
- messageSends: ["trimRight:"],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "trimRight:",
- protocol: 'regular expressions',
- fn: function (separators){
- var self=this;
- function $RegularExpression(){return globals.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)}
- return smalltalk.withContext(function($ctx1) {
- var $3,$2,$1;
- $3=_st("[".__comma(separators)).__comma("]+$");
- $ctx1.sendIdx[","]=1;
- $2=_st($RegularExpression())._fromString_flag_($3,"g");
- $1=self._replaceRegexp_with_($2,"");
- return $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: ''",
- messageSends: ["replaceRegexp:with:", "fromString:flag:", ","],
- referencedClasses: ["RegularExpression"]
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "unescaped",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return unescape(self);
- return self},
- args: [],
- source: "unescaped\x0a\x09<return unescape(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "uriComponentDecoded",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return decodeURIComponent(self);
- return self},
- args: [],
- source: "uriComponentDecoded\x0a\x09<return decodeURIComponent(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "uriComponentEncoded",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return encodeURIComponent(self);
- return self},
- args: [],
- source: "uriComponentEncoded\x0a\x09<return encodeURIComponent(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "uriDecoded",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return decodeURI(self);
- return self},
- args: [],
- source: "uriDecoded\x0a\x09<return decodeURI(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "uriEncoded",
- protocol: 'converting',
- fn: function (){
- var self=this;
- return encodeURI(self);
- return self},
- args: [],
- source: "uriEncoded\x0a\x09<return encodeURI(self)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "cr",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return '\r';
- return self},
- args: [],
- source: "cr\x0a\x09<return '\x5cr'>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "crlf",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return '\r\n';
- return self},
- args: [],
- source: "crlf\x0a\x09<return '\x5cr\x5cn'>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "esc",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._fromCharCode_((27));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"esc",{},globals.String.klass)})},
- args: [],
- source: "esc\x0a\x09^ self fromCharCode: 27",
- messageSends: ["fromCharCode:"],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromCharCode:",
- protocol: 'instance creation',
- fn: function (anInteger){
- var self=this;
- return String.fromCharCode(anInteger);
- return self},
- args: ["anInteger"],
- source: "fromCharCode: anInteger\x0a\x09<return String.fromCharCode(anInteger)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromString:",
- protocol: 'instance creation',
- fn: function (aString){
- var self=this;
- return String(aString);
- return self},
- args: ["aString"],
- source: "fromString: aString\x0a\x09\x09<return String(aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "lf",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return '\n';
- return self},
- args: [],
- source: "lf\x0a\x09<return '\x5cn'>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "random",
- protocol: 'random',
- fn: function (){
- var self=this;
- return (Math.random()*(22/32)+(10/32)).toString(32).slice(2);;
- return self},
- args: [],
- source: "random\x0a\x09\x22Returns random alphanumeric string beginning with letter\x22\x0a\x09<return (Math.random()*(22/32)+(10/32)).toString(32).slice(2);>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "randomNotIn:",
- protocol: 'random',
- fn: function (aString){
- var self=this;
- var result;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- _st((function(){
- return smalltalk.withContext(function($ctx2) {
- result=self._random();
- result;
- return _st(aString)._includesSubString_(result);
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}))._whileTrue();
- $1=result;
- return $1;
- }, 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",
- messageSends: ["whileTrue", "random", "includesSubString:"],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "space",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return ' ';
- return self},
- args: [],
- source: "space\x0a\x09<return ' '>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "streamClass",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- function $StringStream(){return globals.StringStream||(typeof StringStream=="undefined"?nil:StringStream)}
- return $StringStream();
- },
- args: [],
- source: "streamClass\x0a\x09\x09^ StringStream",
- messageSends: [],
- referencedClasses: ["StringStream"]
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "tab",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return '\t';
- return self},
- args: [],
- source: "tab\x0a\x09<return '\x5ct'>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "value:",
- protocol: 'instance creation',
- fn: function (aUTFCharCode){
- var self=this;
- return String.fromCharCode(aUTFCharCode);;
- return self},
- args: ["aUTFCharCode"],
- source: "value: aUTFCharCode\x0a\x0a\x09<return String.fromCharCode(aUTFCharCode);>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.String.klass);
- smalltalk.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`.\x0a";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "=",
- protocol: 'comparing',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$4,$3,$5;
- var $early={};
- try {
- $2=self._class();
- $ctx1.sendIdx["class"]=1;
- $1=_st($2).__eq(_st(aCollection)._class());
- $ctx1.sendIdx["="]=1;
- if(! smalltalk.assert($1)){
- return false;
- };
- $4=self._size();
- $ctx1.sendIdx["size"]=1;
- $3=_st($4).__eq(_st(aCollection)._size());
- if(! smalltalk.assert($3)){
- return false;
- };
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $5=_st(aCollection)._includes_(each);
- if(! smalltalk.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",
- messageSends: ["ifFalse:", "=", "class", "size", "do:", "includes:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:",
- protocol: 'adding/removing',
- fn: function (anObject){
- var self=this;
- var bucket;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- bucket=self._bucketsOfElement_(anObject);
- $2=_st(bucket)._second();
- if(($receiver = $2) == nil || $receiver == null){
- var object,slowBucket;
- object=_st(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- object;
- slowBucket=_st(bucket)._third();
- slowBucket;
- _st(slowBucket)._indexOf_ifAbsent_(object,(function(){
- return smalltalk.withContext(function($ctx2) {
- _st(slowBucket)._add_(object);
- self["@size"]=_st(self["@size"]).__plus((1));
- return self["@size"];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- $1=object;
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- $1=self._add_in_(_st(bucket)._first(),primitiveBucket);
- };
- return $1;
- }, 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 ]",
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "first", "third", "indexOf:ifAbsent:", "add:", "+", "add:in:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "add:in:",
- protocol: 'private',
- fn: function (anObject,anotherObject){
- var self=this;
- if (anObject in anotherObject.store) { return false; }
- self['@size']++;
- return anotherObject.store[anObject] = true;
- ;
- return self},
- args: ["anObject", "anotherObject"],
- source: "add: anObject in: anotherObject\x0a\x09<\x0a\x09\x09if (anObject in anotherObject.store) { return false; }\x0a\x09\x09self['@size']++;\x0a\x09\x09return anotherObject.store[anObject] = true;\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "bucketsOfElement:",
- protocol: 'private',
- fn: function (anObject){
- var self=this;
- var type, bucket, prim = anObject == null ? (anObject = nil) : anObject.valueOf();
- if ((type = typeof prim) === "object") {
- if (anObject !== nil) {
- bucket = null;
- self['@slowBucketStores'].some(function (store) {
- return bucket = store._bucketOfElement_(anObject);
- });
- return [ anObject, null, bucket || self['@defaultBucket'] ];
- }
-
- // include nil to well-known objects under 'boolean' fastBucket
- prim = null;
- type = 'boolean';
- }
- return [ prim, self['@fastBuckets'][type] ];
- ;
- return self},
- 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<\x0a\x09\x09var type, bucket, prim = anObject == null ? (anObject = nil) : anObject.valueOf();\x0a\x09\x09if ((type = typeof prim) === \x22object\x22) {\x0a\x09\x09\x09if (anObject !== nil) {\x0a\x09\x09\x09\x09bucket = null;\x0a\x09\x09\x09\x09self['@slowBucketStores'].some(function (store) {\x0a\x09\x09\x09\x09\x09return bucket = store._bucketOfElement_(anObject);\x0a\x09\x09\x09\x09});\x0a\x09\x09\x09\x09return [ anObject, null, bucket || self['@defaultBucket'] ];\x0a\x09\x09\x09}\x0a\x09\x09\x09\x0a\x09\x09\x09// include nil to well-known objects under 'boolean' fastBucket\x0a\x09\x09\x09prim = null;\x0a\x09\x09\x09type = 'boolean';\x0a\x09\x09}\x0a\x09\x09return [ prim, self['@fastBuckets'][type] ];\x0a\x09>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "classNameOf:",
- protocol: 'private',
- fn: function (anObject){
- var self=this;
- return anObject.klass && anObject.klass.className;
- return self},
- 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<return anObject.klass && anObject.klass.className>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "collect:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var collection;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- collection=_st(self._class())._new();
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(collection)._add_(_st(aBlock)._value_(each));
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $1=collection;
- return $1;
- }, 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",
- messageSends: ["new", "class", "do:", "add:", "value:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "detect:ifNone:",
- protocol: 'enumerating',
- fn: function (aBlock,anotherBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- var $early={};
- try {
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(each);
- if(smalltalk.assert($1)){
- throw $early=[each];
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $2=_st(anotherBlock)._value();
- return $2;
- }
- 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",
- messageSends: ["do:", "ifTrue:", "value:", "value"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- 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},
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09<\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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includes:",
- protocol: 'testing',
- fn: function (anObject){
- var self=this;
- var bucket;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$4,$1;
- bucket=self._bucketsOfElement_(anObject);
- $2=_st(bucket)._second();
- if(($receiver = $2) == nil || $receiver == null){
- $3=_st(bucket)._third();
- $4=_st(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- $1=_st($3)._includes_($4);
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- $1=self._includes_in_(_st(bucket)._first(),primitiveBucket);
- };
- return $1;
- }, 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 ]",
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "includes:", "third", "first", "includes:in:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "includes:in:",
- protocol: 'private',
- fn: function (anObject,anotherObject){
- var self=this;
- return anObject in anotherObject.store;
- return self},
- args: ["anObject", "anotherObject"],
- source: "includes: anObject in: anotherObject\x0a\x09<return anObject in anotherObject.store>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "initialize",
- protocol: 'initialization',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- globals.Set.superclass.fn.prototype._initialize.apply(_st(self), []);
- self["@defaultBucket"]=[];
- self._initializeSlowBucketStores();
- $1=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",
- messageSends: ["initialize", "initializeSlowBucketStores", "removeAll"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "initializeSlowBucketStores",
- protocol: 'initialization',
- fn: function (){
- var self=this;
- function $ArrayBucketStore(){return globals.ArrayBucketStore||(typeof ArrayBucketStore=="undefined"?nil:ArrayBucketStore)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st($ArrayBucketStore())._hashBlock_((function(x){
- return smalltalk.withContext(function($ctx2) {
- return self._classNameOf_(x);
- }, function($ctx2) {$ctx2.fillBlock({x:x},$ctx1,1)})}));
- $ctx1.sendIdx["hashBlock:"]=1;
- self["@slowBucketStores"]=[$1,_st($ArrayBucketStore())._hashBlock_((function(x){
- return smalltalk.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}",
- messageSends: ["hashBlock:", "classNameOf:", "jsConstructorNameOf:"],
- referencedClasses: ["ArrayBucketStore"]
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "jsConstructorNameOf:",
- protocol: 'private',
- fn: function (anObject){
- var self=this;
- return anObject.constructor && anObject.constructor.name;
- return self},
- args: ["anObject"],
- source: "jsConstructorNameOf: anObject\x0a\x09<return anObject.constructor && anObject.constructor.name>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "printOn:",
- protocol: 'printing',
- fn: function (aStream){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- globals.Set.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]);
- $ctx1.sendIdx["printOn:"]=1;
- _st(aStream)._nextPutAll_(" (");
- $ctx1.sendIdx["nextPutAll:"]=1;
- self._do_separatedBy_((function(each){
- return smalltalk.withContext(function($ctx2) {
- return _st(each)._printOn_(aStream);
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}),(function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(aStream)._nextPutAll_(" ");
- $ctx2.sendIdx["nextPutAll:"]=2;
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- _st(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: ')'",
- messageSends: ["printOn:", "nextPutAll:", "do:separatedBy:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:ifAbsent:",
- protocol: 'adding/removing',
- fn: function (anObject,aBlock){
- var self=this;
- var bucket;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$4,$5,$1;
- var $early={};
- try {
- bucket=self._bucketsOfElement_(anObject);
- $2=_st(bucket)._second();
- if(($receiver = $2) == nil || $receiver == null){
- $3=_st(bucket)._third();
- $4=_st(bucket)._first();
- $ctx1.sendIdx["first"]=1;
- _st($3)._remove_ifAbsent_($4,(function(){
- return smalltalk.withContext(function($ctx2) {
- $5=_st(aBlock)._value();
- throw $early=[$5];
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- self["@size"]=_st(self["@size"]).__minus((1));
- $1=self["@size"];
- } else {
- var primitiveBucket;
- primitiveBucket=$receiver;
- $1=self._remove_in_(_st(bucket)._first(),primitiveBucket);
- };
- return $1;
- }
- 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 ]",
- messageSends: ["bucketsOfElement:", "ifNil:ifNotNil:", "second", "remove:ifAbsent:", "third", "first", "value", "-", "remove:in:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "remove:in:",
- protocol: 'private',
- fn: function (anObject,anotherObject){
- var self=this;
- if (delete anotherObject.store[anObject]) self['@size']--;
- return self},
- args: ["anObject", "anotherObject"],
- source: "remove: anObject in: anotherObject\x0a\x09<if (delete anotherObject.store[anObject]) self['@size']-->",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "removeAll",
- protocol: 'adding/removing',
- fn: function (){
- var self=this;
- 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},
- args: [],
- source: "removeAll\x0a\x09<\x0a\x09\x09self['@fastBuckets'] = {\x0a\x09\x09\x09'boolean': { store: Object.create(null), fn: function (x) { return {'true': true, 'false': false, 'null': null}[x]; } },\x0a\x09\x09\x09'number': { store: Object.create(null), fn: Number },\x0a\x09\x09\x09'string': { 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>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "select:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- var collection;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- collection=_st(self._class())._new();
- self._do_((function(each){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(aBlock)._value_(each);
- if(smalltalk.assert($1)){
- return _st(collection)._add_(each);
- };
- }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)})}));
- $2=collection;
- return $2;
- }, 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",
- messageSends: ["new", "class", "do:", "ifTrue:", "value:", "add:"],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@size"];
- return $1;
- },
- args: [],
- source: "size\x0a\x09^ size",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Set);
- smalltalk.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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "initialize",
- protocol: 'initialization',
- fn: function (){
- var self=this;
- function $OrderedCollection(){return globals.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)}
- return smalltalk.withContext(function($ctx1) {
- globals.Queue.superclass.fn.prototype._initialize.apply(_st(self), []);
- self["@read"]=_st($OrderedCollection())._new();
- $ctx1.sendIdx["new"]=1;
- self["@write"]=_st($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",
- messageSends: ["initialize", "new"],
- referencedClasses: ["OrderedCollection"]
- }),
- globals.Queue);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "next",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._nextIfAbsent_((function(){
- return smalltalk.withContext(function($ctx2) {
- return self._error_("Cannot read from empty Queue.");
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"next",{},globals.Queue)})},
- args: [],
- source: "next\x0a\x09^ self nextIfAbsent: [ self error: 'Cannot read from empty Queue.' ]",
- messageSends: ["nextIfAbsent:", "error:"],
- referencedClasses: []
- }),
- globals.Queue);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextIfAbsent:",
- protocol: 'accessing',
- fn: function (aBlock){
- var self=this;
- var result;
- function $OrderedCollection(){return globals.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)}
- return smalltalk.withContext(function($ctx1) {
- var $1,$2,$3,$4;
- var $early={};
- try {
- result=_st(self["@read"])._at_ifAbsent_(self["@readIndex"],(function(){
- return smalltalk.withContext(function($ctx2) {
- $1=_st(self["@write"])._isEmpty();
- if(smalltalk.assert($1)){
- $2=_st(self["@readIndex"]).__gt((1));
- if(smalltalk.assert($2)){
- self["@read"]=[];
- self["@read"];
- self["@readIndex"]=(1);
- self["@readIndex"];
- };
- $3=_st(aBlock)._value();
- throw $early=[$3];
- };
- self["@read"]=self["@write"];
- self["@read"];
- self["@readIndex"]=(1);
- self["@readIndex"];
- self["@write"]=_st($OrderedCollection())._new();
- self["@write"];
- return _st(self["@read"])._first();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- _st(self["@read"])._at_put_(self["@readIndex"],nil);
- self["@readIndex"]=_st(self["@readIndex"]).__plus((1));
- $4=result;
- return $4;
- }
- 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 isEmpty ifTrue: [\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",
- messageSends: ["at:ifAbsent:", "ifTrue:", "isEmpty", ">", "value", "new", "first", "at:put:", "+"],
- referencedClasses: ["OrderedCollection"]
- }),
- globals.Queue);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPut:",
- protocol: 'accessing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(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",
- messageSends: ["add:"],
- referencedClasses: []
- }),
- globals.Queue);
- smalltalk.addClass('RegularExpression', globals.Object, [], 'Kernel-Collections');
- globals.RegularExpression.comment="I represent a regular expression object. My instances are JavaScript `RegExp` object.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "compile:",
- protocol: 'evaluating',
- fn: function (aString){
- var self=this;
- return self.compile(aString);
- return self},
- args: ["aString"],
- source: "compile: aString\x0a\x09<return self.compile(aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.RegularExpression);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "exec:",
- protocol: 'evaluating',
- fn: function (aString){
- var self=this;
- return self.exec(aString) || nil;
- return self},
- args: ["aString"],
- source: "exec: aString\x0a\x09<return self.exec(aString) || nil>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.RegularExpression);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "test:",
- protocol: 'evaluating',
- fn: function (aString){
- var self=this;
- return self.test(aString);
- return self},
- args: ["aString"],
- source: "test: aString\x0a\x09<return self.test(aString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.RegularExpression);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromString:",
- protocol: 'instance creation',
- fn: function (aString){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._fromString_flag_(aString,"");
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},globals.RegularExpression.klass)})},
- args: ["aString"],
- source: "fromString: aString\x0a\x09\x09^ self fromString: aString flag: ''",
- messageSends: ["fromString:flag:"],
- referencedClasses: []
- }),
- globals.RegularExpression.klass);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "fromString:flag:",
- protocol: 'instance creation',
- fn: function (aString,anotherString){
- var self=this;
- return new RegExp(aString, anotherString);
- return self},
- args: ["aString", "anotherString"],
- source: "fromString: aString flag: anotherString\x0a\x09<return new RegExp(aString, anotherString)>",
- messageSends: [],
- referencedClasses: []
- }),
- globals.RegularExpression.klass);
- smalltalk.addClass('Stream', globals.Object, ['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.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "<<",
- protocol: 'writing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._write_(anObject);
- return self}, function($ctx1) {$ctx1.fill(self,"<<",{anObject:anObject},globals.Stream)})},
- args: ["anObject"],
- source: "<< anObject\x0a\x09self write: anObject",
- messageSends: ["write:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "atEnd",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._position()).__eq(self._size());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"atEnd",{},globals.Stream)})},
- args: [],
- source: "atEnd\x0a\x09^ self position = self size",
- messageSends: ["=", "position", "size"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "atStart",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._position()).__eq((0));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"atStart",{},globals.Stream)})},
- args: [],
- source: "atStart\x0a\x09^ self position = 0",
- messageSends: ["=", "position"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "close",
- protocol: 'actions',
- fn: function (){
- var self=this;
- return self},
- args: [],
- source: "close",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "collection",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@collection"];
- return $1;
- },
- args: [],
- source: "collection\x0a\x09^ collection",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "contents",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._collection())._copyFrom_to_((1),self._streamSize());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"contents",{},globals.Stream)})},
- args: [],
- source: "contents\x0a\x09^ self collection\x0a\x09\x09copyFrom: 1\x0a\x09\x09to: self streamSize",
- messageSends: ["copyFrom:to:", "collection", "streamSize"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "do:",
- protocol: 'enumerating',
- fn: function (aBlock){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st((function(){
- return smalltalk.withContext(function($ctx2) {
- return self._atEnd();
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}))._whileFalse_((function(){
- return smalltalk.withContext(function($ctx2) {
- return _st(aBlock)._value_(self._next());
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,2)})}));
- return self}, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},globals.Stream)})},
- args: ["aBlock"],
- source: "do: aBlock\x0a\x09[ self atEnd ] whileFalse: [ aBlock value: self next ]",
- messageSends: ["whileFalse:", "atEnd", "value:", "next"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "flush",
- protocol: 'actions',
- fn: function (){
- var self=this;
- return self},
- args: [],
- source: "flush",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "isEmpty",
- protocol: 'testing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=_st(self._size()).__eq((0));
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"isEmpty",{},globals.Stream)})},
- args: [],
- source: "isEmpty\x0a\x09^ self size = 0",
- messageSends: ["=", "size"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "next",
- protocol: 'reading',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$4,$3,$1;
- $2=self._atEnd();
- if(smalltalk.assert($2)){
- $1=nil;
- } else {
- $4=self._position();
- $ctx1.sendIdx["position"]=1;
- $3=_st($4).__plus((1));
- self._position_($3);
- $1=_st(self["@collection"])._at_(self._position());
- };
- return $1;
- }, 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 ]",
- messageSends: ["ifTrue:ifFalse:", "atEnd", "position:", "+", "position", "at:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "next:",
- protocol: 'reading',
- fn: function (anInteger){
- var self=this;
- var tempCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- tempCollection=_st(_st(self._collection())._class())._new();
- _st(anInteger)._timesRepeat_((function(){
- return smalltalk.withContext(function($ctx2) {
- $1=self._atEnd();
- if(! smalltalk.assert($1)){
- return _st(tempCollection)._add_(self._next());
- };
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- $2=tempCollection;
- return $2;
- }, 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",
- messageSends: ["new", "class", "collection", "timesRepeat:", "ifFalse:", "atEnd", "add:", "next"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPut:",
- protocol: 'writing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1,$3,$4;
- $2=self._position();
- $ctx1.sendIdx["position"]=1;
- $1=_st($2).__plus((1));
- self._position_($1);
- $3=self._collection();
- $4=self._position();
- $ctx1.sendIdx["position"]=2;
- _st($3)._at_put_($4,anObject);
- self._setStreamSize_(_st(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)",
- messageSends: ["position:", "+", "position", "at:put:", "collection", "setStreamSize:", "max:", "streamSize"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPutAll:",
- protocol: 'writing',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(aCollection)._do_((function(each){
- return smalltalk.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.Stream)})},
- args: ["aCollection"],
- source: "nextPutAll: aCollection\x0a\x09aCollection do: [ :each |\x0a\x09\x09self nextPut: each ]",
- messageSends: ["do:", "nextPut:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPutString:",
- protocol: 'writing',
- fn: function (aString){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._nextPut_(aString);
- return self}, function($ctx1) {$ctx1.fill(self,"nextPutString:",{aString:aString},globals.Stream)})},
- args: ["aString"],
- source: "nextPutString: aString\x0a\x09self nextPut: aString",
- messageSends: ["nextPut:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "peek",
- protocol: 'reading',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self._atEnd();
- if(! smalltalk.assert($2)){
- $1=_st(self._collection())._at_(_st(self._position()).__plus((1)));
- };
- return $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 ]",
- messageSends: ["ifFalse:", "atEnd", "at:", "collection", "+", "position"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "position",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$1;
- $2=self["@position"];
- if(($receiver = $2) == nil || $receiver == null){
- self["@position"]=(0);
- $1=self["@position"];
- } else {
- $1=$2;
- };
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"position",{},globals.Stream)})},
- args: [],
- source: "position\x0a\x09^ position ifNil: [ position := 0 ]",
- messageSends: ["ifNil:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "position:",
- protocol: 'accessing',
- fn: function (anInteger){
- var self=this;
- self["@position"]=anInteger;
- return self},
- args: ["anInteger"],
- source: "position: anInteger\x0a\x09position := anInteger",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "reset",
- protocol: 'actions',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._position_((0));
- return self}, function($ctx1) {$ctx1.fill(self,"reset",{},globals.Stream)})},
- args: [],
- source: "reset\x0a\x09self position: 0",
- messageSends: ["position:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "resetContents",
- protocol: 'actions',
- fn: function (){
- var self=this;
- return smalltalk.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",
- messageSends: ["reset", "setStreamSize:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "setCollection:",
- protocol: 'accessing',
- fn: function (aCollection){
- var self=this;
- self["@collection"]=aCollection;
- return self},
- args: ["aCollection"],
- source: "setCollection: aCollection\x0a\x09collection := aCollection",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "setStreamSize:",
- protocol: 'accessing',
- fn: function (anInteger){
- var self=this;
- self["@streamSize"]=anInteger;
- return self},
- args: ["anInteger"],
- source: "setStreamSize: anInteger\x0a\x09streamSize := anInteger",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "setToEnd",
- protocol: 'positioning',
- fn: function (){
- var self=this;
- return smalltalk.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",
- messageSends: ["position:", "size"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "size",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._streamSize();
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"size",{},globals.Stream)})},
- args: [],
- source: "size\x0a\x09^ self streamSize",
- messageSends: ["streamSize"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "skip:",
- protocol: 'positioning',
- fn: function (anInteger){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._position_(_st(_st(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)",
- messageSends: ["position:", "min:max:", "+", "position", "size"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "streamSize",
- protocol: 'accessing',
- fn: function (){
- var self=this;
- var $1;
- $1=self["@streamSize"];
- return $1;
- },
- args: [],
- source: "streamSize\x0a\x09^ streamSize",
- messageSends: [],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "write:",
- protocol: 'writing',
- fn: function (anObject){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- _st(anObject)._putOn_(self);
- return self}, function($ctx1) {$ctx1.fill(self,"write:",{anObject:anObject},globals.Stream)})},
- args: ["anObject"],
- source: "write: anObject\x0a\x09anObject putOn: self",
- messageSends: ["putOn:"],
- referencedClasses: []
- }),
- globals.Stream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "on:",
- protocol: 'instance creation',
- fn: function (aCollection){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- var $2,$3,$1;
- $2=self._new();
- _st($2)._setCollection_(aCollection);
- _st($2)._setStreamSize_(_st(aCollection)._size());
- $3=_st($2)._yourself();
- $1=$3;
- return $1;
- }, 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",
- messageSends: ["setCollection:", "new", "setStreamSize:", "size", "yourself"],
- referencedClasses: []
- }),
- globals.Stream.klass);
- smalltalk.addClass('StringStream', globals.Stream, [], 'Kernel-Collections');
- globals.StringStream.comment="I am a Stream specific to `String` objects.";
- smalltalk.addMethod(
- smalltalk.method({
- selector: "cr",
- protocol: 'writing',
- fn: function (){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._nextPutAll_(_st($String())._cr());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"cr",{},globals.StringStream)})},
- args: [],
- source: "cr\x0a\x09^ self nextPutAll: String cr",
- messageSends: ["nextPutAll:", "cr"],
- referencedClasses: ["String"]
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "crlf",
- protocol: 'writing',
- fn: function (){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._nextPutAll_(_st($String())._crlf());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"crlf",{},globals.StringStream)})},
- args: [],
- source: "crlf\x0a\x09^ self nextPutAll: String crlf",
- messageSends: ["nextPutAll:", "crlf"],
- referencedClasses: ["String"]
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "lf",
- protocol: 'writing',
- fn: function (){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._nextPutAll_(_st($String())._lf());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"lf",{},globals.StringStream)})},
- args: [],
- source: "lf\x0a\x09^ self nextPutAll: String lf",
- messageSends: ["nextPutAll:", "lf"],
- referencedClasses: ["String"]
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "next:",
- protocol: 'reading',
- fn: function (anInteger){
- var self=this;
- var tempCollection;
- return smalltalk.withContext(function($ctx1) {
- var $1,$2;
- tempCollection=_st(_st(self._collection())._class())._new();
- _st(anInteger)._timesRepeat_((function(){
- return smalltalk.withContext(function($ctx2) {
- $1=self._atEnd();
- if(! smalltalk.assert($1)){
- tempCollection=_st(tempCollection).__comma(self._next());
- return tempCollection;
- };
- }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)})}));
- $2=tempCollection;
- return $2;
- }, 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",
- messageSends: ["new", "class", "collection", "timesRepeat:", "ifFalse:", "atEnd", ",", "next"],
- referencedClasses: []
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPut:",
- protocol: 'writing',
- fn: function (aString){
- var self=this;
- return smalltalk.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",
- messageSends: ["nextPutAll:"],
- referencedClasses: []
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPutAll:",
- protocol: 'writing',
- fn: function (aString){
- var self=this;
- var pre,post;
- return smalltalk.withContext(function($ctx1) {
- var $1,$3,$2,$4,$5,$6,$9,$8,$10,$7,$11,$12,$14,$13;
- $1=self._atEnd();
- if(smalltalk.assert($1)){
- $3=self._collection();
- $ctx1.sendIdx["collection"]=1;
- $2=_st($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=_st($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=_st($9).__plus((1));
- $ctx1.sendIdx["+"]=2;
- $10=_st(aString)._size();
- $ctx1.sendIdx["size"]=1;
- $7=_st($8).__plus($10);
- $ctx1.sendIdx["+"]=1;
- $11=_st(self._collection())._size();
- $ctx1.sendIdx["size"]=2;
- post=_st($6)._copyFrom_to_($7,$11);
- post;
- $12=_st(_st(pre).__comma(aString)).__comma(post);
- $ctx1.sendIdx[","]=2;
- self._setCollection_($12);
- };
- $14=self._position();
- $ctx1.sendIdx["position"]=3;
- $13=_st($14).__plus(_st(aString)._size());
- self._position_($13);
- self._setStreamSize_(_st(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)",
- messageSends: ["ifTrue:ifFalse:", "atEnd", "setCollection:", ",", "collection", "copyFrom:to:", "position", "+", "size", "position:", "setStreamSize:", "max:", "streamSize"],
- referencedClasses: []
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "nextPutString:",
- protocol: 'writing',
- fn: function (aString){
- var self=this;
- return smalltalk.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",
- messageSends: ["nextPutAll:"],
- referencedClasses: []
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "space",
- protocol: 'writing',
- fn: function (){
- var self=this;
- return smalltalk.withContext(function($ctx1) {
- self._nextPut_(" ");
- return self}, function($ctx1) {$ctx1.fill(self,"space",{},globals.StringStream)})},
- args: [],
- source: "space\x0a\x09self nextPut: ' '",
- messageSends: ["nextPut:"],
- referencedClasses: []
- }),
- globals.StringStream);
- smalltalk.addMethod(
- smalltalk.method({
- selector: "tab",
- protocol: 'writing',
- fn: function (){
- var self=this;
- function $String(){return globals.String||(typeof String=="undefined"?nil:String)}
- return smalltalk.withContext(function($ctx1) {
- var $1;
- $1=self._nextPutAll_(_st($String())._tab());
- return $1;
- }, function($ctx1) {$ctx1.fill(self,"tab",{},globals.StringStream)})},
- args: [],
- source: "tab\x0a\x09^ self nextPutAll: String tab",
- messageSends: ["nextPutAll:", "tab"],
- referencedClasses: ["String"]
- }),
- globals.StringStream);
- });
|