#!/usr/bin/env node var define = (function amdefine(module, requireFn) { 'use strict'; var defineCache = {}, loaderCache = {}, alreadyCalled = false, path = require('path'), makeRequire, stringRequire; /** * Trims the . and .. from an array of path segments. * It will keep a leading path segment if a .. will become * the first path segment, to help with module name lookups, * which act like paths, but can be remapped. But the end result, * all paths that use this function should look normalized. * NOTE: this method MODIFIES the input array. * @param {Array} ary the array of path segments. */ function trimDots(ary) { var i, part; for (i = 0; ary[i]; i+= 1) { part = ary[i]; if (part === '.') { ary.splice(i, 1); i -= 1; } else if (part === '..') { if (i === 1 && (ary[2] === '..' || ary[0] === '..')) { //End of the line. Keep at least one non-dot //path segment at the front so it can be mapped //correctly to disk. Otherwise, there is likely //no path mapping for a path starting with '..'. //This can still fail, but catches the most reasonable //uses of .. break; } else if (i > 0) { ary.splice(i - 1, 2); i -= 2; } } } } function normalize(name, baseName) { var baseParts; //Adjust any relative paths. if (name && name.charAt(0) === '.') { //If have a base name, try to normalize against it, //otherwise, assume it is a top-level require that will //be relative to baseUrl in the end. if (baseName) { baseParts = baseName.split('/'); baseParts = baseParts.slice(0, baseParts.length - 1); baseParts = baseParts.concat(name.split('/')); trimDots(baseParts); name = baseParts.join('/'); } } return name; } /** * Create the normalize() function passed to a loader plugin's * normalize method. */ function makeNormalize(relName) { return function (name) { return normalize(name, relName); }; } function makeLoad(id) { function load(value) { loaderCache[id] = value; } load.fromText = function (id, text) { //This one is difficult because the text can/probably uses //define, and any relative paths and requires should be relative //to that id was it would be found on disk. But this would require //bootstrapping a module/require fairly deeply from node core. //Not sure how best to go about that yet. throw new Error('amdefine does not implement load.fromText'); }; return load; } makeRequire = function (systemRequire, exports, module, relId) { function amdRequire(deps, callback) { if (typeof deps === 'string') { //Synchronous, single module require('') return stringRequire(systemRequire, exports, module, deps, relId); } else { //Array of dependencies with a callback. //Convert the dependencies to modules. deps = deps.map(function (depName) { return stringRequire(systemRequire, exports, module, depName, relId); }); //Wait for next tick to call back the require call. process.nextTick(function () { callback.apply(null, deps); }); } } amdRequire.toUrl = function (filePath) { if (filePath.indexOf('.') === 0) { return normalize(filePath, path.dirname(module.filename)); } else { return filePath; } }; return amdRequire; }; //Favor explicit value, passed in if the module wants to support Node 0.4. requireFn = requireFn || function req() { return module.require.apply(module, arguments); }; function runFactory(id, deps, factory) { var r, e, m, result; if (id) { e = loaderCache[id] = {}; m = { id: id, uri: __filename, exports: e }; r = makeRequire(requireFn, e, m, id); } else { //Only support one define call per file if (alreadyCalled) { throw new Error('amdefine with no module ID cannot be called more than once per file.'); } alreadyCalled = true; //Use the real variables from node //Use module.exports for exports, since //the exports in here is amdefine exports. e = module.exports; m = module; r = makeRequire(requireFn, e, m, module.id); } //If there are dependencies, they are strings, so need //to convert them to dependency values. if (deps) { deps = deps.map(function (depName) { return r(depName); }); } //Call the factory with the right dependencies. if (typeof factory === 'function') { result = factory.apply(m.exports, deps); } else { result = factory; } if (result !== undefined) { m.exports = result; if (id) { loaderCache[id] = m.exports; } } } stringRequire = function (systemRequire, exports, module, id, relId) { //Split the ID by a ! so that var index = id.indexOf('!'), originalId = id, prefix, plugin; if (index === -1) { id = normalize(id, relId); //Straight module lookup. If it is one of the special dependencies, //deal with it, otherwise, delegate to node. if (id === 'require') { return makeRequire(systemRequire, exports, module, relId); } else if (id === 'exports') { return exports; } else if (id === 'module') { return module; } else if (loaderCache.hasOwnProperty(id)) { return loaderCache[id]; } else if (defineCache[id]) { runFactory.apply(null, defineCache[id]); return loaderCache[id]; } else { if(systemRequire) { return systemRequire(originalId); } else { throw new Error('No module with ID: ' + id); } } } else { //There is a plugin in play. prefix = id.substring(0, index); id = id.substring(index + 1, id.length); plugin = stringRequire(systemRequire, exports, module, prefix, relId); if (plugin.normalize) { id = plugin.normalize(id, makeNormalize(relId)); } else { //Normalize the ID normally. id = normalize(id, relId); } if (loaderCache[id]) { return loaderCache[id]; } else { plugin.load(id, makeRequire(systemRequire, exports, module, relId), makeLoad(id), {}); return loaderCache[id]; } } }; //Create a define function specific to the module asking for amdefine. function define(id, deps, factory) { if (Array.isArray(id)) { factory = deps; deps = id; id = undefined; } else if (typeof id !== 'string') { factory = id; id = deps = undefined; } if (deps && !Array.isArray(deps)) { factory = deps; deps = undefined; } if (!deps) { deps = ['require', 'exports', 'module']; } //Set up properties for this module. If an ID, then use //internal cache. If no ID, then use the external variables //for this node module. if (id) { //Put the module in deep freeze until there is a //require call for it. defineCache[id] = [id, deps, factory]; } else { runFactory(id, deps, factory); } } //define.require, which has access to all the values in the //cache. Useful for AMD modules that all have IDs in the file, //but need to finally export a value to node based on one of those //IDs. define.require = function (id) { if (loaderCache[id]) { return loaderCache[id]; } if (defineCache[id]) { runFactory.apply(null, defineCache[id]); return loaderCache[id]; } }; define.amd = {}; return define; })(), requirejs = define.require; define("amber_vm/browser-compatibility", [], {}); /* ==================================================================== | | Amber Smalltalk | http://amber-lang.net | ====================================================================== ====================================================================== | | Copyright (c) 2010-2011 | Nicolas Petton | | Amber is released under the MIT license | | Permission is hereby granted, free of charge, to any person obtaining | a copy of this software and associated documentation files (the | 'Software'), to deal in the Software without restriction, including | without limitation the rights to use, copy, modify, merge, publish, | distribute, sublicense, and/or sell copies of the Software, and to | permit persons to whom the Software is furnished to do so, subject to | the following conditions: | | The above copyright notice and this permission notice shall be | included in all copies or substantial portions of the Software. | | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ==================================================================== */ define("amber_vm/boot", [ './browser-compatibility' ], function () { /* Reconfigurable micro composition system, https://github.com/amber-smalltalk/brikz */ function Brikz(api, apiKey, initKey) { var brikz = this, backup = {}; apiKey = apiKey || 'exports'; initKey = initKey || '__init__'; function mixin(src, target, what) { for (var keys = Object.keys(what||src), l=keys.length, i=0; i>"+method.selector + " from different class " + klass.className); } delete klass.fn.prototype[st.selector(method.selector)]; delete klass.methods[method.selector]; st.initClass(klass); propagateMethodChange(klass); // Do *not* delete protocols from here. // This is handled by #removeCompiledMethod }; /* Answer all method selectors based on dnu handlers */ st.allSelectors = function() { return dnu.selectors; }; } function AugmentsBrik(brikz, st) { /* Make sure that console is defined */ if(typeof console === "undefined") { this.console = { log: function() {}, warn: function() {}, info: function() {}, debug: function() {}, error: function() {} }; } /* Array extensions */ Array.prototype.addElement = function(el) { if(typeof el === 'undefined') { return; } if(this.indexOf(el) == -1) { this.push(el); } }; Array.prototype.removeElement = function(el) { var i = this.indexOf(el); if (i !== -1) { this.splice(i, 1); } }; } function SmalltalkInitBrik(brikz, st) { brikz.ensure("classInit"); brikz.ensure("classes"); var nil = brikz.ensure("root").nil; var initialized = false; /* Smalltalk initialization. Called on page load */ st.initialize = function() { if(initialized) { return; } st.classes().forEach(function(klass) { st.init(klass); }); runnable(); st.classes().forEach(function(klass) { klass._initialize(); }); initialized = true; }; this.initialized = function () { return initialized; }; this.__init__ = function () { st.addPackage("Kernel-Methods"); st.wrapClassName("Number", "Kernel-Objects", Number, st.Object); st.wrapClassName("BlockClosure", "Kernel-Methods", Function, st.Object); st.wrapClassName("Boolean", "Kernel-Objects", Boolean, st.Object); st.wrapClassName("Date", "Kernel-Objects", Date, st.Object); st.addPackage("Kernel-Collections"); st.addClass("Collection", st.Object, null, "Kernel-Collections"); st.addClass("IndexableCollection", st.Collection, null, "Kernel-Collections"); st.addClass("SequenceableCollection", st.IndexableCollection, null, "Kernel-Collections"); st.addClass("CharacterArray", st.SequenceableCollection, null, "Kernel-Collections"); st.wrapClassName("String", "Kernel-Collections", String, st.CharacterArray); st.wrapClassName("Array", "Kernel-Collections", Array, st.SequenceableCollection); st.wrapClassName("RegularExpression", "Kernel-Collections", RegExp, st.Object); st.addPackage("Kernel-Exceptions"); st.wrapClassName("Error", "Kernel-Exceptions", Error, st.Object); /* Alias definitions */ st.alias(st.Array, "OrderedCollection"); st.alias(st.Date, "Time"); /* * Answer the smalltalk representation of o. * Used in message sends */ st._st = function (o) { if(o == null) {return nil;} if(o.klass) {return o;} return st.JSObjectProxy._on_(o); }; }; } function PrimitivesBrik(brikz, st) { /* Unique ID number generator */ var oid = 0; st.nextId = function() { oid += 1; return oid; }; /* Converts a JavaScript object to valid Smalltalk Object */ st.readJSObject = function(js) { var object = js; var readObject = (js.constructor === Object); var readArray = (js.constructor === Array); if(readObject) { object = st.Dictionary._new(); } for(var i in js) { if(readObject) { object._at_put_(i, st.readJSObject(js[i])); } if(readArray) { object[i] = st.readJSObject(js[i]); } } return object; }; /* Boolean assertion */ st.assert = function(shouldBeBoolean) { if (undefined !== shouldBeBoolean && shouldBeBoolean.klass === st.Boolean) { return shouldBeBoolean == true; } else { st.NonBooleanReceiver._new()._object_(shouldBeBoolean)._signal(); } }; /* List of all reserved words in JavaScript. They may not be used as variables in Smalltalk. */ // list of reserved JavaScript keywords as of // http://es5.github.com/#x7.6.1.1 // and // http://people.mozilla.org/~jorendorff/es6-draft.html#sec-7.6.1 st.reservedWords = ['break', 'case', 'catch', 'continue', 'debugger', 'default', 'delete', 'do', 'else', 'finally', 'for', 'function', 'if', 'in', 'instanceof', 'new', 'return', 'switch', 'this', 'throw', 'try', 'typeof', 'var', 'void', 'while', 'with', // ES5: future use: http://es5.github.com/#x7.6.1.2 'class', 'const', 'enum', 'export', 'extends', 'import', 'super', // ES5: future use in strict mode 'implements', 'interface', 'let', 'package', 'private', 'protected', 'public', 'static', 'yield']; st.globalJsVariables = ['jQuery', 'window', 'document', 'process', 'global']; } function RuntimeBrik(brikz, st) { brikz.ensure("selectorConversion"); var nil = brikz.ensure("root").nil; function SmalltalkMethodContext(home, setup) { this.homeContext = home; this.setup = setup || function() {}; this.pc = 0; } inherits(SmalltalkMethodContext, SmalltalkObject); this.__init__ = function () { st.addPackage("Kernel-Methods"); st.wrapClassName("MethodContext", "Kernel-Methods", SmalltalkMethodContext, st.Object, false); // Fallbacks SmalltalkMethodContext.prototype.locals = {}; SmalltalkMethodContext.prototype.receiver = null; SmalltalkMethodContext.prototype.selector = null; SmalltalkMethodContext.prototype.lookupClass = null; SmalltalkMethodContext.prototype.fill = function(receiver, selector, locals, lookupClass) { this.receiver = receiver; this.selector = selector; this.locals = locals || {}; this.lookupClass = lookupClass; }; SmalltalkMethodContext.prototype.fillBlock = function(locals, ctx, index) { this.locals = locals || {}; this.outerContext = ctx; this.index = index || 0; }; SmalltalkMethodContext.prototype.init = function() { var home = this.homeContext; if(home) { home.init(); } this.setup(this); }; SmalltalkMethodContext.prototype.method = function() { var method; var lookup = this.lookupClass || this.receiver.klass; while(!method && lookup) { method = lookup.methods[st.convertSelector(this.selector)]; lookup = lookup.superclass; } return method; }; }; /* This is the current call context object. While it is publicly available, Use smalltalk.getThisContext() instead which will answer a safe copy of the current context */ st.thisContext = undefined; st.withContext = function(worker, setup) { if(st.thisContext) { st.thisContext.pc++; return inContext(worker, setup); } else { try { return inContext(worker, setup); } catch(error) { handleError(error); } finally { st.thisContext = null; } } }; function inContext(worker, setup) { var context = pushContext(setup); var result = worker(context); popContext(context); return result; } function wrappedError(error) { var errorWrapper = st.JavaScriptException._on_(error); try { errorWrapper._signal(); } catch (ex) {} errorWrapper._context_(st.getThisContext()); return errorWrapper; } /* Handles Smalltalk errors. Triggers the registered ErrorHandler (See the Smalltalk class ErrorHandler and its subclasses */ function handleError(error) { if (!error.smalltalkError) { error = wrappedError(error); } st.ErrorHandler._current()._handleError_(error); // Throw the exception anyway, as we want to stop // the execution to avoid infinite loops // Update: do not throw the exception. It's really annoying. // throw error; } /* Handle thisContext pseudo variable */ st.getThisContext = function() { if(st.thisContext) { st.thisContext.init(); return st.thisContext; } else { return nil; } }; function pushContext(setup) { return st.thisContext = new SmalltalkMethodContext(st.thisContext, setup); } function popContext(context) { st.thisContext = context.homeContext; } } function MessageSendBrik(brikz, st) { brikz.ensure("selectorConversion"); var nil = brikz.ensure("root").nil; /* Handles unhandled errors during message sends */ // simply send the message and handle #dnu: st.send = function(receiver, selector, args, klass) { var method; if(receiver === null) { receiver = nil; } method = klass ? klass.fn.prototype[selector] : receiver.klass && receiver[selector]; if(method) { return method.apply(receiver, args); } else { return messageNotUnderstood(receiver, selector, args); } }; /* Handles #dnu: *and* JavaScript method calls. if the receiver has no klass, we consider it a JS object (outside of the Amber system). Else assume that the receiver understands #doesNotUnderstand: */ function messageNotUnderstood(receiver, selector, args) { /* Handles JS method calls. */ if(receiver.klass === undefined || receiver.allowJavaScriptCalls) { return callJavaScriptMethod(receiver, selector, args); } /* Handles not understood messages. Also see the Amber counter-part Object>>doesNotUnderstand: */ return receiver._doesNotUnderstand_( st.Message._new() ._selector_(st.convertSelector(selector)) ._arguments_(args) ); } /* Call a method of a JS object, or answer a property if it exists. Else try wrapping a JSObjectProxy around the receiver. If the object property is a function, then call it, except if it starts with an uppercase character (we probably want to answer the function itself in this case and send it #new from Amber). Converts keyword-based selectors by using the first keyword only, but keeping all message arguments. Example: "self do: aBlock with: anObject" -> "self.do(aBlock, anObject)" */ function callJavaScriptMethod(receiver, selector, args) { var jsSelector = selector._asJavaScriptSelector(); var jsProperty = receiver[jsSelector]; if(typeof jsProperty === "function" && !/^[A-Z]/.test(jsSelector)) { return jsProperty.apply(receiver, args); } else if(jsProperty !== undefined) { if(args[0]) { receiver[jsSelector] = args[0]; return nil; } else { return jsProperty; } } return st.send(st.JSObjectProxy._on_(receiver), selector, args); } if(typeof jQuery !== "undefined") { jQuery.allowJavaScriptCalls = true; } this.messageNotUnderstood = messageNotUnderstood; } function SelectorConversionBrik(brikz, st) { /* Convert a Smalltalk selector into a JS selector */ st.selector = function(string) { var selector = '_' + string; selector = selector.replace(/:/g, '_'); selector = selector.replace(/[\&]/g, '_and'); selector = selector.replace(/[\|]/g, '_or'); selector = selector.replace(/[+]/g, '_plus'); selector = selector.replace(/-/g, '_minus'); selector = selector.replace(/[*]/g ,'_star'); selector = selector.replace(/[\/]/g ,'_slash'); selector = selector.replace(/[\\]/g ,'_backslash'); selector = selector.replace(/[\~]/g ,'_tild'); selector = selector.replace(/>/g ,'_gt'); selector = selector.replace(/>asSelector accordingly */ st.convertSelector = function(selector) { if(selector.match(/__/)) { return convertBinarySelector(selector); } else { return convertKeywordSelector(selector); } }; function convertKeywordSelector(selector) { return selector.replace(/^_/, '').replace(/_/g, ':'); } function convertBinarySelector(selector) { return selector .replace(/^_/, '') .replace(/_and/g, '&') .replace(/_or/g, '|') .replace(/_plus/g, '+') .replace(/_minus/g, '-') .replace(/_star/g, '*') .replace(/_slash/g, '/') .replace(/_backslash/g, '\\') .replace(/_tild/g, '~') .replace(/_gt/g, '>') .replace(/_lt/g, '<') .replace(/_eq/g, '=') .replace(/_comma/g, ',') .replace(/_at/g, '@'); } } /* Adds AMD and requirejs related methods to the smalltalk object */ function AMDBrik(brikz, st) { this.__init__ = function () { st.amdRequire = st.amdRequire || null; st.defaultTransportType = st.defaultTransportType || "amd"; st.defaultAmdNamespace = st.defaultAmdNamespace || "amber_core"; }; } /* Making smalltalk that can load */ brikz.root = RootBrik; brikz.dnu = DNUBrik; brikz.organize = OrganizeBrik; brikz.selectorConversion = SelectorConversionBrik; brikz.classInit = ClassInitBrik; brikz.manipulation = ManipulationBrik; brikz.classes = ClassesBrik; brikz.methods = MethodsBrik; brikz.stInit = SmalltalkInitBrik; brikz.augments = AugmentsBrik; brikz.amdBrik = AMDBrik; brikz.rebuild(); /* Making smalltalk that can run */ function runnable () { brikz.messageSend = MessageSendBrik; brikz.runtime = RuntimeBrik; brikz.primitives = PrimitivesBrik; brikz.rebuild(); }; var result = { smalltalk: api, nil: brikz.root.nil, _st: api._st }; api._st = null; return result; }); define("amber_vm/smalltalk", ["require", "module", "./boot"], function (require, module, boot) { var smalltalk = boot.smalltalk; smalltalk.amdRequire = require; // var config = module.config && module.config(); // if (config) { // smalltalk.defaultAmdNamespace = config.defaultNamespace; // } return smalltalk; }); define("amber_vm/nil", ["./boot"], function (boot) { return boot.nil; }); define("amber_vm/_st", ["./boot"], function (boot) { return boot._st; }); define("amber_core/Kernel-Objects", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Objects'); smalltalk.packages["Kernel-Objects"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('Object', smalltalk.nil, [], 'Kernel-Objects'); smalltalk.Object.comment="**I am the root of the Smalltalk class system**. All classes in the system are subclasses of me.\x0a\x0aI provide default behavior common to all normal objects, such as:\x0a\x0a- accessing\x0a- copying\x0a- comparison\x0a- error handling\x0a- message sending\x0a- reflection\x0a\x0aAlso utility messages that all objects should respond to are defined here.\x0a\x0aI have no instance variable.\x0a\x0a##Access\x0a\x0aInstance variables can be accessed with `#instVarAt:` and `#instVarAt:put:`. `#instanceVariableNames` answers a collection of all instance variable names.\x0aAccessing JavaScript properties of an object is done through `#basicAt:`, `#basicAt:put:` and `basicDelete:`.\x0a\x0a##Copying\x0a\x0aCopying an object is handled by `#copy` and `#deepCopy`. The first one performs a shallow copy of the receiver, while the second one performs a deep copy.\x0aThe hook method `#postCopy` can be overriden in subclasses to copy fields as necessary to complete the full copy. It will be sent by the copy of the receiver.\x0a\x0a##Comparison\x0a\x0aI understand equality `#=` and identity `#==` comparison.\x0a\x0a##Error handling\x0a\x0a- `#halt` is the typical message to use for inserting breakpoints during debugging.\x0a- `#error:` throws a generic error exception\x0a- `#doesNotUnderstand:` handles the fact that there was an attempt to send the given message to the receiver but the receiver does not understand this message.\x0a\x09Overriding this message can be useful to implement proxies for example."; smalltalk.addMethod( smalltalk.method({ selector: "->", category: 'converting', fn: function (anObject){ var self=this; function $Association(){return smalltalk.Association||(typeof Association=="undefined"?nil:Association)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Association())._key_value_(self,anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"->",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "-> anObject\x0a\x09^Association key: self value: anObject", messageSends: ["key:value:"], referencedClasses: ["Association"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__eq_eq(anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"=",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "= anObject\x0a\x09^self == anObject", messageSends: ["=="], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "==", category: 'comparing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._identityHash()).__eq(_st(anObject)._identityHash()); return $1; }, function($ctx1) {$ctx1.fill(self,"==",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "== anObject\x0a\x09^self identityHash = anObject identityHash", messageSends: ["=", "identityHash"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; var variables; function $HashedCollection(){return smalltalk.HashedCollection||(typeof HashedCollection=="undefined"?nil:HashedCollection)} return smalltalk.withContext(function($ctx1) { var $1; variables=_st($HashedCollection())._new(); _st(_st(self._class())._allInstanceVariableNames())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(variables)._at_put_(each,_st(self._instVarAt_(each))._asJSON()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=variables; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{variables:variables},smalltalk.Object)})}, args: [], source: "asJSON\x0a\x09| variables |\x0a\x09variables := HashedCollection new.\x0a\x09self class allInstanceVariableNames do: [:each |\x0a\x09\x09variables at: each put: (self instVarAt: each) asJSON].\x0a\x09^variables", messageSends: ["new", "do:", "at:put:", "asJSON", "instVarAt:", "allInstanceVariableNames", "class"], referencedClasses: ["HashedCollection"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "asJSONString", category: 'converting', fn: function (){ var self=this; function $JSON(){return smalltalk.JSON||(typeof JSON=="undefined"?nil:JSON)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($JSON())._stringify_(self._asJSON()); return $1; }, function($ctx1) {$ctx1.fill(self,"asJSONString",{},smalltalk.Object)})}, args: [], source: "asJSONString\x0a\x09^JSON stringify: self asJSON", messageSends: ["stringify:", "asJSON"], referencedClasses: ["JSON"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._asString(); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.Object)})}, args: [], source: "asJavascript\x0a\x09^self asString", messageSends: ["asString"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._printString(); return $1; }, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.Object)})}, args: [], source: "asString\x0a\x09^self printString", messageSends: ["printString"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "basicAt:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self[aString]; return self}, function($ctx1) {$ctx1.fill(self,"basicAt:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "basicAt: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "basicAt:put:", category: 'accessing', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { return self[aString] = anObject; return self}, function($ctx1) {$ctx1.fill(self,"basicAt:put:",{aString:aString,anObject:anObject},smalltalk.Object)})}, args: ["aString", "anObject"], source: "basicAt: aString put: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "basicDelete:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { delete self[aString]; return aString; return self}, function($ctx1) {$ctx1.fill(self,"basicDelete:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "basicDelete: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "basicPerform:", category: 'message handling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicPerform_withArguments_(aString,[]); return $1; }, function($ctx1) {$ctx1.fill(self,"basicPerform:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "basicPerform: aString\x0a\x09^self basicPerform: aString withArguments: #()", messageSends: ["basicPerform:withArguments:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "basicPerform:withArguments:", category: 'message handling', fn: function (aString,aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { return self[aString].apply(self, aCollection);; return self}, function($ctx1) {$ctx1.fill(self,"basicPerform:withArguments:",{aString:aString,aCollection:aCollection},smalltalk.Object)})}, args: ["aString", "aCollection"], source: "basicPerform: aString withArguments: aCollection\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "class", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.klass; return self}, function($ctx1) {$ctx1.fill(self,"class",{},smalltalk.Object)})}, args: [], source: "class\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "copy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._shallowCopy())._postCopy(); return $1; }, function($ctx1) {$ctx1.fill(self,"copy",{},smalltalk.Object)})}, args: [], source: "copy\x0a\x09^self shallowCopy postCopy", messageSends: ["postCopy", "shallowCopy"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var copy = self.klass._new(); for(var i in self) { if(/^@.+/.test(i)) { copy[i] = self[i]._deepCopy(); } } return copy; ; return self}, function($ctx1) {$ctx1.fill(self,"deepCopy",{},smalltalk.Object)})}, args: [], source: "deepCopy\x0a\x09<\x0a\x09\x09var copy = self.klass._new();\x0a\x09\x09for(var i in self) {\x0a\x09\x09if(/^@.+/.test(i)) {\x0a\x09\x09\x09copy[i] = self[i]._deepCopy();\x0a\x09\x09}\x0a\x09\x09}\x0a\x09\x09return copy;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "deprecatedAPI", category: 'error handling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(console)._warn_(_st(_st(_st(_st(smalltalk.getThisContext()._home())._asString()).__comma(" is deprecated! (in ")).__comma(_st(_st(smalltalk.getThisContext()._home())._home())._asString())).__comma(")")); return self}, function($ctx1) {$ctx1.fill(self,"deprecatedAPI",{},smalltalk.Object)})}, args: [], source: "deprecatedAPI\x0a\x09\x22Just a simple way to deprecate methods.\x0a\x09#deprecatedAPI is in the 'error handling' protocol even if it doesn't throw an error,\x0a\x09but it could in the future.\x22\x0a\x09console warn: thisContext home asString, ' is deprecated! (in ', thisContext home home asString, ')'", messageSends: ["warn:", ",", "asString", "home"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "doesNotUnderstand:", category: 'error handling', fn: function (aMessage){ var self=this; function $MessageNotUnderstood(){return smalltalk.MessageNotUnderstood||(typeof MessageNotUnderstood=="undefined"?nil:MessageNotUnderstood)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st($MessageNotUnderstood())._new(); _st($1)._receiver_(self); _st($1)._message_(aMessage); $2=_st($1)._signal(); return self}, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage},smalltalk.Object)})}, args: ["aMessage"], source: "doesNotUnderstand: aMessage\x0a\x09MessageNotUnderstood new\x0a\x09\x09receiver: self;\x0a\x09\x09message: aMessage;\x0a\x09\x09signal", messageSends: ["receiver:", "new", "message:", "signal"], referencedClasses: ["MessageNotUnderstood"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "error:", category: 'error handling', fn: function (aString){ var self=this; function $Error(){return smalltalk.Error||(typeof Error=="undefined"?nil:Error)} return smalltalk.withContext(function($ctx1) { _st($Error())._signal_(aString); return self}, function($ctx1) {$ctx1.fill(self,"error:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "error: aString\x0a\x09Error signal: aString", messageSends: ["signal:"], referencedClasses: ["Error"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "halt", category: 'error handling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._error_("Halt encountered"); return self}, function($ctx1) {$ctx1.fill(self,"halt",{},smalltalk.Object)})}, args: [], source: "halt\x0a\x09self error: 'Halt encountered'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "identityHash", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var hash=self.identityHash; if (hash) return hash; hash=smalltalk.nextId(); Object.defineProperty(self, 'identityHash', {value:hash}); return hash; ; return self}, function($ctx1) {$ctx1.fill(self,"identityHash",{},smalltalk.Object)})}, args: [], source: "identityHash\x0a\x09<\x0a\x09var hash=self.identityHash;\x0a\x09if (hash) return hash;\x0a\x09hash=smalltalk.nextId();\x0a\x09Object.defineProperty(self, 'identityHash', {value:hash});\x0a\x09return hash;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:",{aBlock:aBlock},smalltalk.Object)})}, args: ["aBlock"], source: "ifNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:ifNotNil:", category: 'testing', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anotherBlock)._value_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Object)})}, args: ["aBlock", "anotherBlock"], source: "ifNil: aBlock ifNotNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^anotherBlock value: self", messageSends: ["value:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aBlock)._value_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:",{aBlock:aBlock},smalltalk.Object)})}, args: ["aBlock"], source: "ifNotNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^aBlock value: self", messageSends: ["value:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:ifNil:", category: 'testing', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aBlock)._value_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Object)})}, args: ["aBlock", "anotherBlock"], source: "ifNotNil: aBlock ifNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^aBlock value: self", messageSends: ["value:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Object)})}, args: [], source: "initialize", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "inspect", category: 'inspecting', fn: function (){ var self=this; function $InspectorHandler(){return smalltalk.InspectorHandler||(typeof InspectorHandler=="undefined"?nil:InspectorHandler)} return smalltalk.withContext(function($ctx1) { _st($InspectorHandler())._inspect_(self); return self}, function($ctx1) {$ctx1.fill(self,"inspect",{},smalltalk.Object)})}, args: [], source: "inspect\x0a\x09InspectorHandler inspect: self", messageSends: ["inspect:"], referencedClasses: ["InspectorHandler"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "inspectOn:", category: 'inspecting', fn: function (anInspector){ var self=this; var variables; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $1,$2; variables=_st($Dictionary())._new(); _st(variables)._at_put_("#self",self); _st(_st(self._class())._allInstanceVariableNames())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(variables)._at_put_(each,self._instVarAt_(each)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=anInspector; _st($1)._setLabel_(self._printString()); $2=_st($1)._setVariables_(variables); return self}, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},smalltalk.Object)})}, args: ["anInspector"], source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self.\x0a\x09self class allInstanceVariableNames do: [:each |\x0a\x09\x09variables at: each put: (self instVarAt: each)].\x0a\x09anInspector\x0a\x09\x09setLabel: self printString;\x0a\x09\x09setVariables: variables", messageSends: ["new", "at:put:", "do:", "instVarAt:", "allInstanceVariableNames", "class", "setLabel:", "printString", "setVariables:"], referencedClasses: ["Dictionary"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "instVarAt:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self['@'+aString] ; return self}, function($ctx1) {$ctx1.fill(self,"instVarAt:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "instVarAt: aString\x0a\x09< return self['@'+aString] >", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "instVarAt:put:", category: 'accessing', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self['@' + aString] = anObject ; return self}, function($ctx1) {$ctx1.fill(self,"instVarAt:put:",{aString:aString,anObject:anObject},smalltalk.Object)})}, args: ["aString", "anObject"], source: "instVarAt: aString put: anObject\x0a\x09< self['@' + aString] = anObject >", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isBehavior", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isBehavior",{},smalltalk.Object)})}, args: [], source: "isBehavior\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isBoolean", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isBoolean",{},smalltalk.Object)})}, args: [], source: "isBoolean\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isClass", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isClass",{},smalltalk.Object)})}, args: [], source: "isClass\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isCompiledMethod", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isCompiledMethod",{},smalltalk.Object)})}, args: [], source: "isCompiledMethod\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.Object)})}, args: [], source: "isImmutable\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isKindOf:", category: 'testing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._isMemberOf_(aClass); if(smalltalk.assert($2)){ $1=true; } else { $1=_st(self._class())._inheritsFrom_(aClass); }; return $1; }, function($ctx1) {$ctx1.fill(self,"isKindOf:",{aClass:aClass},smalltalk.Object)})}, args: ["aClass"], source: "isKindOf: aClass\x0a\x09^(self isMemberOf: aClass)\x0a\x09\x09ifTrue: [true]\x0a\x09\x09ifFalse: [self class inheritsFrom: aClass]", messageSends: ["ifTrue:ifFalse:", "inheritsFrom:", "class", "isMemberOf:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isMemberOf:", category: 'testing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._class()).__eq(aClass); return $1; }, function($ctx1) {$ctx1.fill(self,"isMemberOf:",{aClass:aClass},smalltalk.Object)})}, args: ["aClass"], source: "isMemberOf: aClass\x0a\x09^self class = aClass", messageSends: ["=", "class"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isMetaclass", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isMetaclass",{},smalltalk.Object)})}, args: [], source: "isMetaclass\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isNil", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isNil",{},smalltalk.Object)})}, args: [], source: "isNil\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isNumber", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isNumber",{},smalltalk.Object)})}, args: [], source: "isNumber\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isPackage", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isPackage",{},smalltalk.Object)})}, args: [], source: "isPackage\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isParseFailure", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isParseFailure",{},smalltalk.Object)})}, args: [], source: "isParseFailure\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isString", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isString",{},smalltalk.Object)})}, args: [], source: "isString\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "isSymbol", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isSymbol",{},smalltalk.Object)})}, args: [], source: "isSymbol\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "notNil", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._isNil())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"notNil",{},smalltalk.Object)})}, args: [], source: "notNil\x0a\x09^self isNil not", messageSends: ["not", "isNil"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "perform:", category: 'message handling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._perform_withArguments_(aString,[]); return $1; }, function($ctx1) {$ctx1.fill(self,"perform:",{aString:aString},smalltalk.Object)})}, args: ["aString"], source: "perform: aString\x0a\x09^self perform: aString withArguments: #()", messageSends: ["perform:withArguments:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "perform:withArguments:", category: 'message handling', fn: function (aString,aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.send(self, aString._asSelector(), aCollection); return self}, function($ctx1) {$ctx1.fill(self,"perform:withArguments:",{aString:aString,aCollection:aCollection},smalltalk.Object)})}, args: ["aString", "aCollection"], source: "perform: aString withArguments: aCollection\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "postCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"postCopy",{},smalltalk.Object)})}, args: [], source: "postCopy", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$3,$2; $1=aStream; $3=_st(_st(_st(self._class())._name())._first())._isVowel(); if(smalltalk.assert($3)){ $2="an "; } else { $2="a "; }; _st($1)._nextPutAll_($2); _st(aStream)._nextPutAll_(_st(self._class())._name()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Object)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09\x22Append to the aStream, a string representing the receiver.\x22\x0a\x09\x0a\x09aStream nextPutAll: (self class name first isVowel\x0a\x09\x09ifTrue: [ 'an ' ]\x0a\x09\x09ifFalse: [ 'a ' ]).\x0a\x09aStream nextPutAll: self class name", messageSends: ["nextPutAll:", "ifTrue:ifFalse:", "isVowel", "first", "name", "class"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "printString", category: 'printing', fn: function (){ var self=this; function $String(){return smalltalk.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 self._printOn_(stream); }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"printString",{},smalltalk.Object)})}, args: [], source: "printString\x0a\x09\x22Answer a String representation of the receiver.\x22\x0a\x0a\x09^ String streamContents: [ :stream | self printOn: stream ]", messageSends: ["streamContents:", "printOn:"], referencedClasses: ["String"] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "putOn:", category: 'streaming', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPut_(self); return self}, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},smalltalk.Object)})}, args: ["aStream"], source: "putOn: aStream\x0a\x09aStream nextPut: self", messageSends: ["nextPut:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "respondsTo:", category: 'testing', fn: function (aSelector){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._class())._canUnderstand_(aSelector); return $1; }, function($ctx1) {$ctx1.fill(self,"respondsTo:",{aSelector:aSelector},smalltalk.Object)})}, args: ["aSelector"], source: "respondsTo: aSelector\x0a\x09^self class canUnderstand: aSelector", messageSends: ["canUnderstand:", "class"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var copy = self.klass._new(); for(var i in self) { if(/^@.+/.test(i)) { copy[i] = self[i]; } } return copy; ; return self}, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},smalltalk.Object)})}, args: [], source: "shallowCopy\x0a\x09<\x0a\x09\x09var copy = self.klass._new();\x0a\x09\x09for(var i in self) {\x0a\x09\x09if(/^@.+/.test(i)) {\x0a\x09\x09\x09copy[i] = self[i];\x0a\x09\x09}\x0a\x09\x09}\x0a\x09\x09return copy;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "shouldNotImplement", category: 'error handling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._error_("This method should not be implemented in ".__comma(_st(self._class())._name())); return self}, function($ctx1) {$ctx1.fill(self,"shouldNotImplement",{},smalltalk.Object)})}, args: [], source: "shouldNotImplement\x0a\x09self error: 'This method should not be implemented in ', self class name", messageSends: ["error:", ",", "name", "class"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._error_("Object not indexable"); return self}, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.Object)})}, args: [], source: "size\x0a\x09self error: 'Object not indexable'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "subclassResponsibility", category: 'error handling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._error_("This method is a responsibility of a subclass"); return self}, function($ctx1) {$ctx1.fill(self,"subclassResponsibility",{},smalltalk.Object)})}, args: [], source: "subclassResponsibility\x0a\x09self error: 'This method is a responsibility of a subclass'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "test", category: 'converting', fn: function (){ var self=this; var a; return smalltalk.withContext(function($ctx1) { a=(1); self._halt(); return self}, function($ctx1) {$ctx1.fill(self,"test",{a:a},smalltalk.Object)})}, args: [], source: "test\x0a\x09| a |\x0a\x09a := 1.\x0a\x09self halt", messageSends: ["halt"], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "throw:", category: 'error handling', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { throw anObject ; return self}, function($ctx1) {$ctx1.fill(self,"throw:",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "throw: anObject\x0a\x09< throw anObject >", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "try:catch:", category: 'error handling', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { try{return aBlock._value()} catch(e) {return anotherBlock._value_(e)}; return self}, function($ctx1) {$ctx1.fill(self,"try:catch:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Object)})}, args: ["aBlock", "anotherBlock"], source: "try: aBlock catch: anotherBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.valueOf(); return self}, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.Object)})}, args: [], source: "value\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "yourself", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"yourself",{},smalltalk.Object)})}, args: [], source: "yourself\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "~=", category: 'comparing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self.__eq(anObject)).__eq(false); return $1; }, function($ctx1) {$ctx1.fill(self,"~=",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "~= anObject\x0a\x09^(self = anObject) = false", messageSends: ["="], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "~~", category: 'comparing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self.__eq_eq(anObject)).__eq(false); return $1; }, function($ctx1) {$ctx1.fill(self,"~~",{anObject:anObject},smalltalk.Object)})}, args: ["anObject"], source: "~~ anObject\x0a\x09^(self == anObject) = false", messageSends: ["=", "=="], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "class"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Object.klass)})}, args: [], source: "heliosClass\x0a\x09\x22Should be an Helios extension. Unfortunately, since helios can browse remote\x0a\x09environments, we can't extend base classes\x22\x0a\x09\x0a\x09^ 'class'", messageSends: [], referencedClasses: [] }), smalltalk.Object.klass); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Object.klass)})}, args: [], source: "initialize\x0a\x09\x22no op\x22", messageSends: [], referencedClasses: [] }), smalltalk.Object.klass); smalltalk.addClass('Boolean', smalltalk.Object, [], 'Kernel-Objects'); smalltalk.Boolean.comment="I define the protocol for logic testing operations and conditional control structures for the logical values (see the `controlling` protocol).\x0a\x0aI have two instances, `true` and `false`.\x0a\x0aI am directly mapped to JavaScript Boolean. The `true` and `false` objects are the JavaScript boolean objects.\x0a\x0a## Usage Example:\x0a\x0a aBoolean not ifTrue: [ ... ] ifFalse: [ ... ]"; smalltalk.addMethod( smalltalk.method({ selector: "&", category: 'controlling', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { if(self == true) { return aBoolean; } else { return false; } ; return self}, function($ctx1) {$ctx1.fill(self,"&",{aBoolean:aBoolean},smalltalk.Boolean)})}, args: ["aBoolean"], source: "& aBoolean\x0a\x09<\x0a\x09\x09if(self == true) {\x0a\x09\x09return aBoolean;\x0a\x09\x09} else {\x0a\x09\x09return false;\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { if(! aBoolean._isBoolean || ! aBoolean._isBoolean()) { return false; } return Boolean(self == true) == aBoolean ; return self}, function($ctx1) {$ctx1.fill(self,"=",{aBoolean:aBoolean},smalltalk.Boolean)})}, args: ["aBoolean"], source: "= aBoolean\x0a\x09<\x0a\x09\x09if(! aBoolean._isBoolean || ! aBoolean._isBoolean()) {\x0a\x09\x09\x09return false;\x0a\x09\x09}\x0a\x09\x09return Boolean(self == true) == aBoolean\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "==", category: 'comparing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__eq(aBoolean); return $1; }, function($ctx1) {$ctx1.fill(self,"==",{aBoolean:aBoolean},smalltalk.Boolean)})}, args: ["aBoolean"], source: "== aBoolean\x0a\x09^self = aBoolean", messageSends: ["="], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "and:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self.__eq(true); $1=_st($2)._ifTrue_ifFalse_(aBlock,(function(){ return smalltalk.withContext(function($ctx2) { return false; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"and:",{aBlock:aBlock},smalltalk.Boolean)})}, args: ["aBlock"], source: "and: aBlock\x0a\x09^self = true\x0a\x09\x09ifTrue: aBlock\x0a\x09\x09ifFalse: [false]", messageSends: ["ifTrue:ifFalse:", "="], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "asBit", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self; if(smalltalk.assert($2)){ $1=(1); } else { $1=(0); }; return $1; }, function($ctx1) {$ctx1.fill(self,"asBit",{},smalltalk.Boolean)})}, args: [], source: "asBit\x0a\x09^ self ifTrue: [ 1 ] ifFalse: [ 0 ]", messageSends: ["ifTrue:ifFalse:"], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.Boolean)})}, args: [], source: "asJSON\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toString() ; return self}, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.Boolean)})}, args: [], source: "asString\x0a\x09< return self.toString() >", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},smalltalk.Boolean)})}, args: [], source: "deepCopy\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "ifFalse:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self; $1=_st($2)._ifTrue_ifFalse_((function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"ifFalse:",{aBlock:aBlock},smalltalk.Boolean)})}, args: ["aBlock"], source: "ifFalse: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self ifTrue: [] ifFalse: aBlock", messageSends: ["ifTrue:ifFalse:"], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "ifFalse:ifTrue:", category: 'controlling', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self; $1=_st($2)._ifTrue_ifFalse_(anotherBlock,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"ifFalse:ifTrue:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Boolean)})}, args: ["aBlock", "anotherBlock"], source: "ifFalse: aBlock ifTrue: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self ifTrue: anotherBlock ifFalse: aBlock", messageSends: ["ifTrue:ifFalse:"], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "ifTrue:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self; $1=_st($2)._ifTrue_ifFalse_(aBlock,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"ifTrue:",{aBlock:aBlock},smalltalk.Boolean)})}, args: ["aBlock"], source: "ifTrue: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self ifTrue: aBlock ifFalse: []", messageSends: ["ifTrue:ifFalse:"], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "ifTrue:ifFalse:", category: 'controlling', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { if(self == true) { return aBlock._value(); } else { return anotherBlock._value(); } ; return self}, function($ctx1) {$ctx1.fill(self,"ifTrue:ifFalse:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Boolean)})}, args: ["aBlock", "anotherBlock"], source: "ifTrue: aBlock ifFalse: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09<\x0a\x09\x09if(self == true) {\x0a\x09\x09return aBlock._value();\x0a\x09\x09} else {\x0a\x09\x09return anotherBlock._value();\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "isBoolean", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isBoolean",{},smalltalk.Boolean)})}, args: [], source: "isBoolean\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.Boolean)})}, args: [], source: "isImmutable\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "not", category: 'controlling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__eq(false); return $1; }, function($ctx1) {$ctx1.fill(self,"not",{},smalltalk.Boolean)})}, args: [], source: "not\x0a\x09^self = false", messageSends: ["="], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "or:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self.__eq(true); $1=_st($2)._ifTrue_ifFalse_((function(){ return smalltalk.withContext(function($ctx2) { return true; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"or:",{aBlock:aBlock},smalltalk.Boolean)})}, args: ["aBlock"], source: "or: aBlock\x0a\x09^self = true\x0a\x09\x09ifTrue: [true]\x0a\x09\x09ifFalse: aBlock", messageSends: ["ifTrue:ifFalse:", "="], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_(self._asString()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Boolean)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString", messageSends: ["nextPutAll:", "asString"], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},smalltalk.Boolean)})}, args: [], source: "shallowCopy\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addMethod( smalltalk.method({ selector: "|", category: 'controlling', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { if(self == true) { return true; } else { return aBoolean; } ; return self}, function($ctx1) {$ctx1.fill(self,"|",{aBoolean:aBoolean},smalltalk.Boolean)})}, args: ["aBoolean"], source: "| aBoolean\x0a\x09<\x0a\x09\x09if(self == true) {\x0a\x09\x09return true;\x0a\x09\x09} else {\x0a\x09\x09return aBoolean;\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Boolean); smalltalk.addClass('Date', smalltalk.Object, [], 'Kernel-Objects'); smalltalk.Date.comment="I am used to work with both dates and times. Therefore `Date today` and `Date now` are both valid in\x0aAmber and answer the same date object.\x0a\x0aDate directly maps to the `Date()` JavaScript constructor, and Amber date objects are JavaScript date objects.\x0a\x0a## API\x0a\x0aThe class-side `instance creation` protocol contains some convenience methods for creating date/time objects such as `#fromSeconds:`.\x0a\x0aArithmetic and comparison is supported (see the `comparing` and `arithmetic` protocols).\x0a\x0aThe `converting` protocol provides convenience methods for various convertions (to numbers, strings, etc.)."; smalltalk.addMethod( smalltalk.method({ selector: "+", category: 'arithmetic', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self + aDate; return self}, function($ctx1) {$ctx1.fill(self,"+",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: "+ aDate\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "-", category: 'arithmetic', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self - aDate; return self}, function($ctx1) {$ctx1.fill(self,"-",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: "- aDate\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "<", category: 'comparing', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self < aDate; return self}, function($ctx1) {$ctx1.fill(self,"<",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: "< aDate\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "<=", category: 'comparing', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self <= aDate; return self}, function($ctx1) {$ctx1.fill(self,"<=",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: "<= aDate\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: ">", category: 'comparing', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self > aDate; return self}, function($ctx1) {$ctx1.fill(self,">",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: "> aDate\x0a\x09> aDate>", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: ">=", category: 'comparing', fn: function (aDate){ var self=this; return smalltalk.withContext(function($ctx1) { return self >= aDate; return self}, function($ctx1) {$ctx1.fill(self,">=",{aDate:aDate},smalltalk.Date)})}, args: ["aDate"], source: ">= aDate\x0a\x09>= aDate>", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asDateString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toDateString(); return self}, function($ctx1) {$ctx1.fill(self,"asDateString",{},smalltalk.Date)})}, args: [], source: "asDateString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asLocaleString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toLocaleString(); return self}, function($ctx1) {$ctx1.fill(self,"asLocaleString",{},smalltalk.Date)})}, args: [], source: "asLocaleString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asMilliseconds", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._time(); return $1; }, function($ctx1) {$ctx1.fill(self,"asMilliseconds",{},smalltalk.Date)})}, args: [], source: "asMilliseconds\x0a\x09^self time", messageSends: ["time"], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asNumber", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._asMilliseconds(); return $1; }, function($ctx1) {$ctx1.fill(self,"asNumber",{},smalltalk.Date)})}, args: [], source: "asNumber\x0a\x09^self asMilliseconds", messageSends: ["asMilliseconds"], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toString(); return self}, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.Date)})}, args: [], source: "asString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "asTimeString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toTimeString(); return self}, function($ctx1) {$ctx1.fill(self,"asTimeString",{},smalltalk.Date)})}, args: [], source: "asTimeString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "day", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._dayOfWeek(); return $1; }, function($ctx1) {$ctx1.fill(self,"day",{},smalltalk.Date)})}, args: [], source: "day\x0a\x09^self dayOfWeek", messageSends: ["dayOfWeek"], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "day:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self._dayOfWeek_(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"day:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "day: aNumber\x0a\x09self dayOfWeek: aNumber", messageSends: ["dayOfWeek:"], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "dayOfMonth", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getDate(); return self}, function($ctx1) {$ctx1.fill(self,"dayOfMonth",{},smalltalk.Date)})}, args: [], source: "dayOfMonth\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "dayOfMonth:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setDate(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"dayOfMonth:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "dayOfMonth: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "dayOfWeek", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getDay() + 1; return self}, function($ctx1) {$ctx1.fill(self,"dayOfWeek",{},smalltalk.Date)})}, args: [], source: "dayOfWeek\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "dayOfWeek:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self.setDay(aNumber - 1); return self}, function($ctx1) {$ctx1.fill(self,"dayOfWeek:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "dayOfWeek: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "hours", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getHours(); return self}, function($ctx1) {$ctx1.fill(self,"hours",{},smalltalk.Date)})}, args: [], source: "hours\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "hours:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setHours(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"hours:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "hours: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "milliseconds", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getMilliseconds(); return self}, function($ctx1) {$ctx1.fill(self,"milliseconds",{},smalltalk.Date)})}, args: [], source: "milliseconds\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "milliseconds:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setMilliseconds(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"milliseconds:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "milliseconds: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "minutes", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getMinutes(); return self}, function($ctx1) {$ctx1.fill(self,"minutes",{},smalltalk.Date)})}, args: [], source: "minutes\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "minutes:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setMinutes(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"minutes:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "minutes: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "month", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getMonth() + 1; return self}, function($ctx1) {$ctx1.fill(self,"month",{},smalltalk.Date)})}, args: [], source: "month\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "month:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setMonth(aNumber - 1); return self}, function($ctx1) {$ctx1.fill(self,"month:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "month: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_(self._asString()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Date)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString", messageSends: ["nextPutAll:", "asString"], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "seconds", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getSeconds(); return self}, function($ctx1) {$ctx1.fill(self,"seconds",{},smalltalk.Date)})}, args: [], source: "seconds\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "seconds:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setSeconds(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"seconds:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "seconds: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "time", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getTime(); return self}, function($ctx1) {$ctx1.fill(self,"time",{},smalltalk.Date)})}, args: [], source: "time\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "time:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setTime(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"time:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "time: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "year", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.getFullYear(); return self}, function($ctx1) {$ctx1.fill(self,"year",{},smalltalk.Date)})}, args: [], source: "year\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "year:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.setFullYear(aNumber); return self}, function($ctx1) {$ctx1.fill(self,"year:",{aNumber:aNumber},smalltalk.Date)})}, args: ["aNumber"], source: "year: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date); smalltalk.addMethod( smalltalk.method({ selector: "fromMilliseconds:", category: 'instance creation', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._new_(aNumber); return $1; }, function($ctx1) {$ctx1.fill(self,"fromMilliseconds:",{aNumber:aNumber},smalltalk.Date.klass)})}, args: ["aNumber"], source: "fromMilliseconds: aNumber\x0a\x09^self new: aNumber", messageSends: ["new:"], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromSeconds:", category: 'instance creation', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._fromMilliseconds_(_st(aNumber).__star((1000))); return $1; }, function($ctx1) {$ctx1.fill(self,"fromSeconds:",{aNumber:aNumber},smalltalk.Date.klass)})}, args: ["aNumber"], source: "fromSeconds: aNumber\x0a\x09^self fromMilliseconds: aNumber * 1000", messageSends: ["fromMilliseconds:", "*"], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromString:", category: 'instance creation', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._new_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},smalltalk.Date.klass)})}, args: ["aString"], source: "fromString: aString\x0a\x09\x22Example: Date fromString('2011/04/15 00:00:00')\x22\x0a\x09^self new: aString", messageSends: ["new:"], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "magnitude"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Date.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'magnitude'", messageSends: [], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "millisecondsToRun:", category: 'instance creation', fn: function (aBlock){ var self=this; var t; function $Date(){return smalltalk.Date||(typeof Date=="undefined"?nil:Date)} return smalltalk.withContext(function($ctx1) { var $1; t=_st($Date())._now(); _st(aBlock)._value(); $1=_st(_st($Date())._now()).__minus(t); return $1; }, function($ctx1) {$ctx1.fill(self,"millisecondsToRun:",{aBlock:aBlock,t:t},smalltalk.Date.klass)})}, args: ["aBlock"], source: "millisecondsToRun: aBlock\x0a\x09| t |\x0a\x09t := Date now.\x0a\x09aBlock value.\x0a\x09^Date now - t", messageSends: ["now", "value", "-"], referencedClasses: ["Date"] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "new:", category: 'instance creation', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { return new Date(anObject); return self}, function($ctx1) {$ctx1.fill(self,"new:",{anObject:anObject},smalltalk.Date.klass)})}, args: ["anObject"], source: "new: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "now", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._today(); return $1; }, function($ctx1) {$ctx1.fill(self,"now",{},smalltalk.Date.klass)})}, args: [], source: "now\x0a\x09^self today", messageSends: ["today"], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addMethod( smalltalk.method({ selector: "today", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"today",{},smalltalk.Date.klass)})}, args: [], source: "today\x0a\x09^self new", messageSends: ["new"], referencedClasses: [] }), smalltalk.Date.klass); smalltalk.addClass('Number', smalltalk.Object, [], 'Kernel-Objects'); smalltalk.Number.comment="I am the Amber representation for all numbers.\x0aI am directly mapped to JavaScript Number.\x0a\x0a## API\x0a\x0aI provide all necessary methods for arithmetic operations, comparison, conversion and so on with numbers.\x0a\x0aMy instances can also be used to evaluate a block a fixed number of times:\x0a\x0a\x095 timesRepeat: [Transcript show: 'This will be printed 5 times'; cr].\x0a\x09\x0a\x091 to: 5 do: [:aNumber| Transcript show: aNumber asString; cr].\x0a\x09\x0a\x091 to: 10 by: 2 do: [:aNumber| Transcript show: aNumber asString; cr]."; smalltalk.addMethod( smalltalk.method({ selector: "&", category: 'converting', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self & aNumber; return self}, function($ctx1) {$ctx1.fill(self,"&",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "& aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "*", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self * aNumber; return self}, function($ctx1) {$ctx1.fill(self,"*",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "* aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "+", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self + aNumber; return self}, function($ctx1) {$ctx1.fill(self,"+",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "+ aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "-", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self - aNumber; return self}, function($ctx1) {$ctx1.fill(self,"-",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "- aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "/", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self / aNumber; return self}, function($ctx1) {$ctx1.fill(self,"/",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "/ aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "<", category: 'comparing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self < aNumber; return self}, function($ctx1) {$ctx1.fill(self,"<",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "< aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "<=", category: 'comparing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self <= aNumber; return self}, function($ctx1) {$ctx1.fill(self,"<=",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "<= aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { if(! aNumber._isNumber || ! aNumber._isNumber()) { return false; } return Number(self) == aNumber ; return self}, function($ctx1) {$ctx1.fill(self,"=",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "= aNumber\x0a\x09<\x0a\x09\x09if(! aNumber._isNumber || ! aNumber._isNumber()) {\x0a\x09\x09\x09return false;\x0a\x09\x09}\x0a\x09\x09return Number(self) == aNumber\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: ">", category: 'comparing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self > aNumber; return self}, function($ctx1) {$ctx1.fill(self,">",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "> aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09> aNumber>", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: ">=", category: 'comparing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self >= aNumber; return self}, function($ctx1) {$ctx1.fill(self,">=",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: ">= aNumber\x0a\x09\x22Inlined in the Compiler\x22\x0a\x09>= aNumber>", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "@", category: 'converting', fn: function (aNumber){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(self,aNumber); return $1; }, function($ctx1) {$ctx1.fill(self,"@",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "@ aNumber\x0a\x09^Point x: self y: aNumber", messageSends: ["x:y:"], referencedClasses: ["Point"] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "\x5c\x5c", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self % aNumber; return self}, function($ctx1) {$ctx1.fill(self,"\x5c\x5c",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "\x5c\x5c aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "abs", category: 'arithmetic', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.abs(self);; return self}, function($ctx1) {$ctx1.fill(self,"abs",{},smalltalk.Number)})}, args: [], source: "abs\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.Number)})}, args: [], source: "asJSON\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("(".__comma(self._printString())).__comma(")"); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.Number)})}, args: [], source: "asJavascript\x0a\x09^'(', self printString, ')'", messageSends: [",", "printString"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "asNumber", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asNumber",{},smalltalk.Number)})}, args: [], source: "asNumber\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "asPoint", category: 'converting', fn: function (){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(self,self); return $1; }, function($ctx1) {$ctx1.fill(self,"asPoint",{},smalltalk.Number)})}, args: [], source: "asPoint\x0a\x09^Point x: self y: self", messageSends: ["x:y:"], referencedClasses: ["Point"] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self) ; return self}, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.Number)})}, args: [], source: "asString\x0a\x09< return String(self) >", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "atRandom", category: 'converting', fn: function (){ var self=this; function $Random(){return smalltalk.Random||(typeof Random=="undefined"?nil:Random)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(_st(_st($Random())._new())._next()).__star(self))._truncated()).__plus((1)); return $1; }, function($ctx1) {$ctx1.fill(self,"atRandom",{},smalltalk.Number)})}, args: [], source: "atRandom\x0a\x09^(Random new next * self) truncated + 1", messageSends: ["+", "truncated", "*", "next", "new"], referencedClasses: ["Random"] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "ceiling", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.ceil(self);; return self}, function($ctx1) {$ctx1.fill(self,"ceiling",{},smalltalk.Number)})}, args: [], source: "ceiling\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "copy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"copy",{},smalltalk.Number)})}, args: [], source: "copy\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._copy(); return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},smalltalk.Number)})}, args: [], source: "deepCopy\x0a\x09^self copy", messageSends: ["copy"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "even", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=(0).__eq(self.__backslash_backslash((2))); return $1; }, function($ctx1) {$ctx1.fill(self,"even",{},smalltalk.Number)})}, args: [], source: "even\x0a\x09^ 0 = (self \x5c\x5c 2)", messageSends: ["=", "\x5c\x5c"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "floor", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.floor(self);; return self}, function($ctx1) {$ctx1.fill(self,"floor",{},smalltalk.Number)})}, args: [], source: "floor\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "identityHash", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._asString()).__comma("n"); return $1; }, function($ctx1) {$ctx1.fill(self,"identityHash",{},smalltalk.Number)})}, args: [], source: "identityHash\x0a\x09^self asString, 'n'", messageSends: [",", "asString"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.Number)})}, args: [], source: "isImmutable\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "isNumber", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isNumber",{},smalltalk.Number)})}, args: [], source: "isNumber\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "isZero", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__eq((0)); return $1; }, function($ctx1) {$ctx1.fill(self,"isZero",{},smalltalk.Number)})}, args: [], source: "isZero\x0a\x09^self = 0", messageSends: ["="], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "max:", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.max(self, aNumber);; return self}, function($ctx1) {$ctx1.fill(self,"max:",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "max: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "min:", category: 'arithmetic', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.min(self, aNumber);; return self}, function($ctx1) {$ctx1.fill(self,"min:",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "min: aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "negated", category: 'arithmetic', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=(0).__minus(self); return $1; }, function($ctx1) {$ctx1.fill(self,"negated",{},smalltalk.Number)})}, args: [], source: "negated\x0a\x09^0 - self", messageSends: ["-"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "negative", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__lt((0)); return $1; }, function($ctx1) {$ctx1.fill(self,"negative",{},smalltalk.Number)})}, args: [], source: "negative\x0a\x09\x22Answer whether the receiver is mathematically negative.\x22\x0a\x0a\x09^ self < 0", messageSends: ["<"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "odd", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._even())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"odd",{},smalltalk.Number)})}, args: [], source: "odd\x0a\x09^ self even not", messageSends: ["not", "even"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "positive", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__gt_eq((0)); return $1; }, function($ctx1) {$ctx1.fill(self,"positive",{},smalltalk.Number)})}, args: [], source: "positive\x0a\x09\x22Answer whether the receiver is positive or equal to 0. (ST-80 protocol).\x22\x0a\x0a\x09^ self >= 0", messageSends: [">="], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_(self._asString()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Number)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: self asString", messageSends: ["nextPutAll:", "asString"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "printShowingDecimalPlaces:", category: 'printing', fn: function (placesDesired){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toFixed(placesDesired); return self}, function($ctx1) {$ctx1.fill(self,"printShowingDecimalPlaces:",{placesDesired:placesDesired},smalltalk.Number)})}, args: ["placesDesired"], source: "printShowingDecimalPlaces: placesDesired\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "rounded", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.round(self);; return self}, function($ctx1) {$ctx1.fill(self,"rounded",{},smalltalk.Number)})}, args: [], source: "rounded\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "sqrt", category: 'arithmetic', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.sqrt(self); return self}, function($ctx1) {$ctx1.fill(self,"sqrt",{},smalltalk.Number)})}, args: [], source: "sqrt\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "squared", category: 'arithmetic', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self.__star(self); return $1; }, function($ctx1) {$ctx1.fill(self,"squared",{},smalltalk.Number)})}, args: [], source: "squared\x0a\x09^self * self", messageSends: ["*"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "timesRepeat:", category: 'enumerating', fn: function (aBlock){ var self=this; var count; return smalltalk.withContext(function($ctx1) { count=(1); _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(count).__gt(self); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { _st(aBlock)._value(); count=_st(count).__plus((1)); return count; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"timesRepeat:",{aBlock:aBlock,count:count},smalltalk.Number)})}, args: ["aBlock"], source: "timesRepeat: aBlock\x0a\x09| count |\x0a\x09count := 1.\x0a\x09[count > self] whileFalse: [\x0a\x09\x09aBlock value.\x0a\x09\x09count := count + 1]", messageSends: ["whileFalse:", "value", "+", ">"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "to:", category: 'converting', fn: function (aNumber){ var self=this; var array,first,last,count; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1; first=self._truncated(); last=_st(_st(aNumber)._truncated()).__plus((1)); count=(1); array=_st($Array())._new(); _st(_st(last).__minus(first))._timesRepeat_((function(){ return smalltalk.withContext(function($ctx2) { _st(array)._at_put_(count,first); count=_st(count).__plus((1)); count; first=_st(first).__plus((1)); return first; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=array; return $1; }, function($ctx1) {$ctx1.fill(self,"to:",{aNumber:aNumber,array:array,first:first,last:last,count:count},smalltalk.Number)})}, args: ["aNumber"], source: "to: aNumber\x0a\x09| array first last count |\x0a\x09first := self truncated.\x0a\x09last := aNumber truncated + 1.\x0a\x09count := 1.\x0a\x09array := Array new.\x0a\x09(last - first) timesRepeat: [\x0a\x09\x09array at: count put: first.\x0a\x09\x09count := count + 1.\x0a\x09\x09first := first + 1].\x0a\x09^array", messageSends: ["truncated", "+", "new", "timesRepeat:", "at:put:", "-"], referencedClasses: ["Array"] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "to:by:", category: 'converting', fn: function (stop,step){ var self=this; var array,value,pos; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; value=self; array=_st($Array())._new(); pos=(1); $1=_st(step).__eq((0)); if(smalltalk.assert($1)){ self._error_("step must be non-zero"); }; $2=_st(step).__lt((0)); if(smalltalk.assert($2)){ _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(value).__gt_eq(stop); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { _st(array)._at_put_(pos,value); pos=_st(pos).__plus((1)); pos; value=_st(value).__plus(step); return value; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); } else { _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(value).__lt_eq(stop); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { _st(array)._at_put_(pos,value); pos=_st(pos).__plus((1)); pos; value=_st(value).__plus(step); return value; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); }; $3=array; return $3; }, function($ctx1) {$ctx1.fill(self,"to:by:",{stop:stop,step:step,array:array,value:value,pos:pos},smalltalk.Number)})}, args: ["stop", "step"], source: "to: stop by: step\x0a\x09| array value pos |\x0a\x09value := self.\x0a\x09array := Array new.\x0a\x09pos := 1.\x0a\x09step = 0 ifTrue: [self error: 'step must be non-zero'].\x0a\x09step < 0\x0a\x09\x09ifTrue: [[ value >= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09array at: pos put: value.\x0a\x09\x09\x09\x09\x09pos := pos + 1.\x0a\x09\x09\x09\x09\x09value := value + step]]\x0a\x09\x09ifFalse: [[ value <= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09array at: pos put: value.\x0a\x09\x09\x09\x09pos := pos + 1.\x0a\x09\x09\x09\x09\x09value := value + step]].\x0a\x09^array", messageSends: ["new", "ifTrue:", "error:", "=", "ifTrue:ifFalse:", "whileTrue:", "at:put:", "+", ">=", "<=", "<"], referencedClasses: ["Array"] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "to:by:do:", category: 'enumerating', fn: function (stop,step,aBlock){ var self=this; var value; return smalltalk.withContext(function($ctx1) { var $1,$2; value=self; $1=_st(step).__eq((0)); if(smalltalk.assert($1)){ self._error_("step must be non-zero"); }; $2=_st(step).__lt((0)); if(smalltalk.assert($2)){ _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(value).__gt_eq(stop); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { _st(aBlock)._value_(value); value=_st(value).__plus(step); return value; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); } else { _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(value).__lt_eq(stop); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { _st(aBlock)._value_(value); value=_st(value).__plus(step); return value; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); }; return self}, function($ctx1) {$ctx1.fill(self,"to:by:do:",{stop:stop,step:step,aBlock:aBlock,value:value},smalltalk.Number)})}, args: ["stop", "step", "aBlock"], source: "to: stop by: step do: aBlock\x0a\x09| value |\x0a\x09value := self.\x0a\x09step = 0 ifTrue: [self error: 'step must be non-zero'].\x0a\x09step < 0\x0a\x09\x09ifTrue: [[ value >= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09aBlock value: value.\x0a\x09\x09\x09\x09\x09value := value + step]]\x0a\x09\x09ifFalse: [[ value <= stop ] whileTrue: [\x0a\x09\x09\x09\x09\x09aBlock value: value.\x0a\x09\x09\x09\x09\x09value := value + step]]", messageSends: ["ifTrue:", "error:", "=", "ifTrue:ifFalse:", "whileTrue:", "value:", "+", ">=", "<=", "<"], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "to:do:", category: 'enumerating', fn: function (stop,aBlock){ var self=this; var nextValue; return smalltalk.withContext(function($ctx1) { nextValue=self; _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(nextValue).__lt_eq(stop); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { _st(aBlock)._value_(nextValue); nextValue=_st(nextValue).__plus((1)); return nextValue; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"to:do:",{stop:stop,aBlock:aBlock,nextValue:nextValue},smalltalk.Number)})}, args: ["stop", "aBlock"], source: "to: stop do: aBlock\x0a\x09\x22Evaluate aBlock for each number from self to aNumber.\x22\x0a\x09| nextValue |\x0a\x09nextValue := self.\x0a\x09[nextValue <= stop]\x0a\x09\x09whileTrue:\x0a\x09\x09\x09[aBlock value: nextValue.\x0a\x09\x09\x09nextValue := nextValue + 1]", messageSends: ["whileTrue:", "value:", "+", "<="], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "truncated", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { if(self >= 0) { return Math.floor(self); } else { return Math.floor(self * (-1)) * (-1); }; ; return self}, function($ctx1) {$ctx1.fill(self,"truncated",{},smalltalk.Number)})}, args: [], source: "truncated\x0a\x09<\x0a\x09\x09if(self >>= 0) {\x0a\x09\x09\x09return Math.floor(self);\x0a\x09\x09} else {\x0a\x09\x09\x09return Math.floor(self * (-1)) * (-1);\x0a\x09\x09};\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "|", category: 'converting', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { return self | aNumber; return self}, function($ctx1) {$ctx1.fill(self,"|",{aNumber:aNumber},smalltalk.Number)})}, args: ["aNumber"], source: "| aNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "magnitude"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Number.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'magnitude'", messageSends: [], referencedClasses: [] }), smalltalk.Number.klass); smalltalk.addMethod( smalltalk.method({ selector: "pi", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.PI; return self}, function($ctx1) {$ctx1.fill(self,"pi",{},smalltalk.Number.klass)})}, args: [], source: "pi\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Number.klass); smalltalk.addClass('Point', smalltalk.Object, ['x', 'y'], 'Kernel-Objects'); smalltalk.Point.comment="I represent an x-y pair of numbers usually designating a geometric coordinate.\x0a\x0a## API\x0a\x0aInstances are traditionally created using the binary `#@` message to a number:\x0a\x0a\x09100@120\x0a\x0aPoints can then be arithmetically manipulated:\x0a\x0a\x09100@100 + (10@10)\x0a\x0a...or for example:\x0a\x0a\x09(100@100) * 2\x0a\x0a**NOTE:** Creating a point with a negative y-value will need a space after `@` in order to avoid a parsing error:\x0a\x0a\x09100@ -100 \x22but 100@-100 would not parse\x22"; smalltalk.addMethod( smalltalk.method({ selector: "*", category: 'arithmetic', fn: function (aPoint){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(_st(self._x()).__star(_st(_st(aPoint)._asPoint())._x()),_st(self._y()).__star(_st(_st(aPoint)._asPoint())._y())); return $1; }, function($ctx1) {$ctx1.fill(self,"*",{aPoint:aPoint},smalltalk.Point)})}, args: ["aPoint"], source: "* aPoint\x0a\x09^Point x: self x * aPoint asPoint x y: self y * aPoint asPoint y", messageSends: ["x:y:", "*", "x", "asPoint", "y"], referencedClasses: ["Point"] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "+", category: 'arithmetic', fn: function (aPoint){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(_st(self._x()).__plus(_st(_st(aPoint)._asPoint())._x()),_st(self._y()).__plus(_st(_st(aPoint)._asPoint())._y())); return $1; }, function($ctx1) {$ctx1.fill(self,"+",{aPoint:aPoint},smalltalk.Point)})}, args: ["aPoint"], source: "+ aPoint\x0a\x09^Point x: self x + aPoint asPoint x y: self y + aPoint asPoint y", messageSends: ["x:y:", "+", "x", "asPoint", "y"], referencedClasses: ["Point"] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "-", category: 'arithmetic', fn: function (aPoint){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(_st(self._x()).__minus(_st(_st(aPoint)._asPoint())._x()),_st(self._y()).__minus(_st(_st(aPoint)._asPoint())._y())); return $1; }, function($ctx1) {$ctx1.fill(self,"-",{aPoint:aPoint},smalltalk.Point)})}, args: ["aPoint"], source: "- aPoint\x0a\x09^Point x: self x - aPoint asPoint x y: self y - aPoint asPoint y", messageSends: ["x:y:", "-", "x", "asPoint", "y"], referencedClasses: ["Point"] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "/", category: 'arithmetic', fn: function (aPoint){ var self=this; function $Point(){return smalltalk.Point||(typeof Point=="undefined"?nil:Point)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Point())._x_y_(_st(self._x()).__slash(_st(_st(aPoint)._asPoint())._x()),_st(self._y()).__slash(_st(_st(aPoint)._asPoint())._y())); return $1; }, function($ctx1) {$ctx1.fill(self,"/",{aPoint:aPoint},smalltalk.Point)})}, args: ["aPoint"], source: "/ aPoint\x0a\x09^Point x: self x / aPoint asPoint x y: self y / aPoint asPoint y", messageSends: ["x:y:", "/", "x", "asPoint", "y"], referencedClasses: ["Point"] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'arithmetic', fn: function (aPoint){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(aPoint)._class()).__eq(self._class()))._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(aPoint)._x()).__eq(self._x())).__and(_st(_st(aPoint)._y()).__eq(self._y())); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"=",{aPoint:aPoint},smalltalk.Point)})}, args: ["aPoint"], source: "= aPoint\x0a\x09^aPoint class = self class and: [\x0a\x09\x09(aPoint x = self x) & (aPoint y = self y)]", messageSends: ["and:", "&", "=", "y", "x", "class"], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "asPoint", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asPoint",{},smalltalk.Point)})}, args: [], source: "asPoint\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(self["@x"])._printOn_(aStream); _st(aStream)._nextPutAll_("@"); $1=_st(_st(self["@y"])._notNil())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@y"])._negative(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($1)){ _st(aStream)._space(); }; _st(self["@y"])._printOn_(aStream); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Point)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09\x22Print receiver in classic x@y notation.\x22\x0a\x0a\x09x printOn: aStream.\x0a\x09\x0a\x09aStream nextPutAll: '@'.\x0a\x09(y notNil and: [y negative]) ifTrue: [\x0a\x09\x09\x09\x22Avoid ambiguous @- construct\x22\x0a\x09\x09\x09aStream space ].\x0a\x09\x0a\x09y printOn: aStream", messageSends: ["printOn:", "nextPutAll:", "ifTrue:", "space", "and:", "negative", "notNil"], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "translateBy:", category: 'transforming', fn: function (delta){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(delta)._x()).__plus(self["@x"])).__at(_st(_st(delta)._y()).__plus(self["@y"])); return $1; }, function($ctx1) {$ctx1.fill(self,"translateBy:",{delta:delta},smalltalk.Point)})}, args: ["delta"], source: "translateBy: delta\x0a\x09\x22Answer a Point translated by delta (an instance of Point).\x22\x0a\x09^(delta x + x) @ (delta y + y)", messageSends: ["@", "+", "y", "x"], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "x", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@x"]; return $1; }, function($ctx1) {$ctx1.fill(self,"x",{},smalltalk.Point)})}, args: [], source: "x\x0a\x09^x", messageSends: [], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "x:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self["@x"]=aNumber; return self}, function($ctx1) {$ctx1.fill(self,"x:",{aNumber:aNumber},smalltalk.Point)})}, args: ["aNumber"], source: "x: aNumber\x0a\x09x := aNumber", messageSends: [], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "y", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@y"]; return $1; }, function($ctx1) {$ctx1.fill(self,"y",{},smalltalk.Point)})}, args: [], source: "y\x0a\x09^y", messageSends: [], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "y:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self["@y"]=aNumber; return self}, function($ctx1) {$ctx1.fill(self,"y:",{aNumber:aNumber},smalltalk.Point)})}, args: ["aNumber"], source: "y: aNumber\x0a\x09y := aNumber", messageSends: [], referencedClasses: [] }), smalltalk.Point); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "magnitude"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Point.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'magnitude'", messageSends: [], referencedClasses: [] }), smalltalk.Point.klass); smalltalk.addMethod( smalltalk.method({ selector: "x:y:", category: 'instance creation', fn: function (aNumber,anotherNumber){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._x_(aNumber); _st($2)._y_(anotherNumber); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"x:y:",{aNumber:aNumber,anotherNumber:anotherNumber},smalltalk.Point.klass)})}, args: ["aNumber", "anotherNumber"], source: "x: aNumber y: anotherNumber\x0a\x09^self new\x0a\x09\x09x: aNumber;\x0a\x09\x09y: anotherNumber;\x0a\x09\x09yourself", messageSends: ["x:", "new", "y:", "yourself"], referencedClasses: [] }), smalltalk.Point.klass); smalltalk.addClass('Random', smalltalk.Object, [], 'Kernel-Objects'); smalltalk.Random.comment="I an used to generate a random number and I am implemented as a trivial wrapper around javascript `Math.random()`.\x0a\x0a## API\x0a\x0aThe typical use case it to use the `#next` method like the following:\x0a\x0a\x09Random new next\x0a\x0aThis will return a float x where x < 1 and x > 0. If you want a random integer from 1 to 10 you can use `#atRandom`\x0a\x0a\x0910 atRandom\x0a\x0aA random number in a specific interval can be obtained with the following:\x0a\x0a\x09(3 to: 7) atRandom\x0a\x0aBe aware that `#to:` does not create an Interval as in other Smalltalk implementations but in fact an `Array` of numbers, so it's better to use:\x0a\x0a\x095 atRandom + 2\x0a\x0aSince `#atRandom` is implemented in `SequencableCollection` you can easy pick an element at random:\x0a\x0a\x09#('a' 'b' 'c') atRandom\x0a\x0aAs well as letter from a `String`:\x0a\x0a\x09'abc' atRandom\x0a\x0aSince Amber does not have Characters this will return a `String` of length 1 like for example `'b'`."; smalltalk.addMethod( smalltalk.method({ selector: "next", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Math.random(); return self}, function($ctx1) {$ctx1.fill(self,"next",{},smalltalk.Random)})}, args: [], source: "next\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Random); smalltalk.addMethod( smalltalk.method({ selector: "next:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st((1)._to_(anInteger))._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return self._next(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger},smalltalk.Random)})}, args: ["anInteger"], source: "next: anInteger\x0a\x09^(1 to: anInteger) collect: [:each | self next]", messageSends: ["collect:", "next", "to:"], referencedClasses: [] }), smalltalk.Random); smalltalk.addClass('UndefinedObject', smalltalk.Object, [], 'Kernel-Objects'); smalltalk.UndefinedObject.comment="I describe the behavior of my sole instance, `nil`. `nil` represents a prior value for variables that have not been initialized, or for results which are meaningless.\x0a\x0a`nil` is the Smalltalk equivalent of the `undefined` JavaScript object.\x0a\x0a__note:__ When sending messages to the `undefined` JavaScript object, it will be replaced by `nil`."; smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=null; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.UndefinedObject)})}, args: [], source: "asJSON\x0a\x09^null", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},smalltalk.UndefinedObject)})}, args: [], source: "deepCopy\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self; $1=_st($2)._ifNil_ifNotNil_(aBlock,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:",{aBlock:aBlock},smalltalk.UndefinedObject)})}, args: ["aBlock"], source: "ifNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self ifNil: aBlock ifNotNil: []", messageSends: ["ifNil:ifNotNil:"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:ifNotNil:", category: 'testing', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aBlock)._value(); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.UndefinedObject)})}, args: ["aBlock", "anotherBlock"], source: "ifNil: aBlock ifNotNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^aBlock value", messageSends: ["value"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:",{aBlock:aBlock},smalltalk.UndefinedObject)})}, args: ["aBlock"], source: "ifNotNil: aBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:ifNil:", category: 'testing', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anotherBlock)._value(); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.UndefinedObject)})}, args: ["aBlock", "anotherBlock"], source: "ifNotNil: aBlock ifNil: anotherBlock\x0a\x09\x22inlined in the Compiler\x22\x0a\x09^anotherBlock value", messageSends: ["value"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.UndefinedObject)})}, args: [], source: "isImmutable\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "isNil", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isNil",{},smalltalk.UndefinedObject)})}, args: [], source: "isNil\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "notNil", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"notNil",{},smalltalk.UndefinedObject)})}, args: [], source: "notNil\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_("nil"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.UndefinedObject)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: 'nil'", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{},smalltalk.UndefinedObject)})}, args: [], source: "shallowCopy\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:", category: 'class creation', fn: function (aString,anotherString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._subclass_instanceVariableNames_package_(aString,anotherString,nil); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:",{aString:aString,anotherString:anotherString},smalltalk.UndefinedObject)})}, args: ["aString", "anotherString"], source: "subclass: aString instanceVariableNames: anotherString\x0a\x09^self subclass: aString instanceVariableNames: anotherString package: nil", messageSends: ["subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:category:", category: 'class creation', fn: function (aString,aString2,aString3){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._deprecatedAPI(); $1=self._subclass_instanceVariableNames_package_(aString,aString2,aString3); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:category:",{aString:aString,aString2:aString2,aString3:aString3},smalltalk.UndefinedObject)})}, args: ["aString", "aString2", "aString3"], source: "subclass: aString instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for compatibility.\x22\x0a\x09self deprecatedAPI.\x0a\x09^self subclass: aString instanceVariableNames: aString2 package: aString3", messageSends: ["deprecatedAPI", "subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:package:", category: 'class creation', fn: function (aString,aString2,aString3){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($ClassBuilder())._new())._superclass_subclass_instanceVariableNames_package_(self,_st(aString)._asString(),aString2,aString3); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:package:",{aString:aString,aString2:aString2,aString3:aString3},smalltalk.UndefinedObject)})}, args: ["aString", "aString2", "aString3"], source: "subclass: aString instanceVariableNames: aString2 package: aString3\x0a\x09^ClassBuilder new\x0a\x09\x09superclass: self subclass: aString asString instanceVariableNames: aString2 package: aString3", messageSends: ["superclass:subclass:instanceVariableNames:package:", "asString", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.UndefinedObject); smalltalk.addMethod( smalltalk.method({ selector: "new", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._error_("You cannot create new instances of UndefinedObject. Use nil"); return self}, function($ctx1) {$ctx1.fill(self,"new",{},smalltalk.UndefinedObject.klass)})}, args: [], source: "new\x0a\x09\x09self error: 'You cannot create new instances of UndefinedObject. Use nil'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.UndefinedObject.klass); }); define("amber_core/Kernel-Classes", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Classes'); smalltalk.packages["Kernel-Classes"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('Behavior', smalltalk.Object, [], 'Kernel-Classes'); smalltalk.Behavior.comment="I am the superclass of all class objects.\x0a\x0aI define the protocol for creating instances of a class with `#basicNew` and `#new` (see `boot.js` for class constructors details).\x0a\x0aMy instances know about the subclass/superclass relationships between classes, contain the description that instances are created from,\x0aand hold the method dictionary that's associated with each class.\x0a\x0aI also provides methods for compiling methods, examining the method dictionary, and iterating over the class hierarchy."; smalltalk.addMethod( smalltalk.method({ selector: ">>", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._methodAt_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,">>",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: ">> aString\x0a\x09^ self methodAt: aString", messageSends: ["methodAt:"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "addCompiledMethod:", category: 'compiling', fn: function (aMethod){ var self=this; var oldMethod,announcement; function $MethodAdded(){return smalltalk.MethodAdded||(typeof MethodAdded=="undefined"?nil:MethodAdded)} function $MethodModified(){return smalltalk.MethodModified||(typeof MethodModified=="undefined"?nil:MethodModified)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6; oldMethod=_st(self._methodDictionary())._at_ifAbsent_(_st(aMethod)._selector(),(function(){ return smalltalk.withContext(function($ctx2) { return nil; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=_st(self._protocols())._includes_(_st(aMethod)._protocol()); if(! smalltalk.assert($1)){ _st(self._organization())._addElement_(_st(aMethod)._protocol()); }; self._basicAddCompiledMethod_(aMethod); $2=oldMethod; if(($receiver = $2) == nil || $receiver == undefined){ $3=_st($MethodAdded())._new(); _st($3)._method_(aMethod); $4=_st($3)._yourself(); announcement=$4; } else { $5=_st($MethodModified())._new(); _st($5)._oldMethod_(oldMethod); _st($5)._method_(aMethod); $6=_st($5)._yourself(); announcement=$6; }; _st(_st($SystemAnnouncer())._current())._announce_(announcement); return self}, function($ctx1) {$ctx1.fill(self,"addCompiledMethod:",{aMethod:aMethod,oldMethod:oldMethod,announcement:announcement},smalltalk.Behavior)})}, args: ["aMethod"], source: "addCompiledMethod: aMethod\x0a\x09| oldMethod announcement |\x0a\x09\x0a\x09oldMethod := self methodDictionary\x0a\x09\x09at: aMethod selector\x0a\x09\x09ifAbsent: [ nil ].\x0a\x09\x0a\x09(self protocols includes: aMethod protocol)\x0a\x09\x09ifFalse: [ self organization addElement: aMethod protocol ].\x0a\x0a\x09self basicAddCompiledMethod: aMethod.\x0a\x09\x0a\x09announcement := oldMethod\x0a\x09\x09ifNil: [\x0a\x09\x09\x09MethodAdded new\x0a\x09\x09\x09\x09\x09method: aMethod;\x0a\x09\x09\x09\x09\x09yourself ]\x0a\x09\x09ifNotNil: [\x0a\x09\x09\x09MethodModified new\x0a\x09\x09\x09\x09\x09oldMethod: oldMethod;\x0a\x09\x09\x09\x09\x09method: aMethod;\x0a\x09\x09\x09\x09\x09yourself ].\x0a\x09\x09\x09\x09\x09\x0a\x09\x09\x09\x09\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09\x09\x09announce: announcement", messageSends: ["at:ifAbsent:", "selector", "methodDictionary", "ifFalse:", "addElement:", "protocol", "organization", "includes:", "protocols", "basicAddCompiledMethod:", "ifNil:ifNotNil:", "method:", "new", "yourself", "oldMethod:", "announce:", "current"], referencedClasses: ["MethodAdded", "MethodModified", "SystemAnnouncer"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "allInstanceVariableNames", category: 'accessing', fn: function (){ var self=this; var result; return smalltalk.withContext(function($ctx1) { var $1,$2; result=_st(self._instanceVariableNames())._copy(); $1=self._superclass(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { _st(result)._addAll_(_st(self._superclass())._allInstanceVariableNames()); }; $2=result; return $2; }, function($ctx1) {$ctx1.fill(self,"allInstanceVariableNames",{result:result},smalltalk.Behavior)})}, args: [], source: "allInstanceVariableNames\x0a\x09| result |\x0a\x09result := self instanceVariableNames copy.\x0a\x09self superclass ifNotNil: [\x0a\x09\x09result addAll: self superclass allInstanceVariableNames].\x0a\x09^result", messageSends: ["copy", "instanceVariableNames", "ifNotNil:", "addAll:", "allInstanceVariableNames", "superclass"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "allSelectors", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $1=_st(self._allSuperclasses())._inject_into_(self._selectors(),(function(acc,each){ return smalltalk.withContext(function($ctx2) { $2=acc; _st($2)._addAll_(_st(each)._selectors()); $3=_st($2)._yourself(); return $3; }, function($ctx2) {$ctx2.fillBlock({acc:acc,each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"allSelectors",{},smalltalk.Behavior)})}, args: [], source: "allSelectors\x0a\x09^ self allSuperclasses\x0a\x09\x09inject: self selectors\x0a\x09\x09into: [ :acc :each | acc addAll: each selectors; yourself ]", messageSends: ["inject:into:", "selectors", "addAll:", "yourself", "allSuperclasses"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "allSubclasses", category: 'accessing', fn: function (){ var self=this; var subclasses,index; return smalltalk.withContext(function($ctx1) { var $1; subclasses=self._subclasses(); index=(1); _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(index).__gt(_st(subclasses)._size()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { _st(subclasses)._addAll_(_st(_st(subclasses)._at_(index))._subclasses()); index=_st(index).__plus((1)); return index; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=subclasses; return $1; }, function($ctx1) {$ctx1.fill(self,"allSubclasses",{subclasses:subclasses,index:index},smalltalk.Behavior)})}, args: [], source: "allSubclasses\x0a\x09\x22Answer an collection of the receiver's and the receiver's descendent's subclasses. \x22\x0a\x0a\x09| subclasses index |\x0a\x09\x0a\x09subclasses := self subclasses.\x0a\x09index := 1.\x0a\x09[ index > subclasses size ]\x0a\x09\x09whileFalse: [ subclasses addAll: (subclasses at: index) subclasses.\x0a\x09\x09\x09index := index + 1 ].\x0a\x0a\x09^ subclasses", messageSends: ["subclasses", "whileFalse:", "addAll:", "at:", "+", ">", "size"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "allSubclassesDo:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._allSubclasses())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(aBlock)._value_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"allSubclassesDo:",{aBlock:aBlock},smalltalk.Behavior)})}, args: ["aBlock"], source: "allSubclassesDo: aBlock\x0a\x09\x22Evaluate the argument, aBlock, for each of the receiver's subclasses.\x22\x0a\x0a\x09self allSubclasses do: [ :each |\x0a \x09aBlock value: each ]", messageSends: ["do:", "value:", "allSubclasses"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "allSuperclasses", category: 'accessing', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $1,$2,$4,$5,$3; $1=self._superclass(); if(($receiver = $1) == nil || $receiver == undefined){ $2=[]; return $2; } else { $1; }; $4=_st($OrderedCollection())._with_(self._superclass()); _st($4)._addAll_(_st(self._superclass())._allSuperclasses()); $5=_st($4)._yourself(); $3=$5; return $3; }, function($ctx1) {$ctx1.fill(self,"allSuperclasses",{},smalltalk.Behavior)})}, args: [], source: "allSuperclasses\x0a\x09\x0a\x09self superclass ifNil: [ ^ #() ].\x0a\x09\x0a\x09^ (OrderedCollection with: self superclass)\x0a\x09\x09addAll: self superclass allSuperclasses;\x0a\x09\x09yourself", messageSends: ["ifNil:", "superclass", "addAll:", "allSuperclasses", "with:", "yourself"], referencedClasses: ["OrderedCollection"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "basicAddCompiledMethod:", category: 'private', fn: function (aMethod){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.addMethod(aMethod, self); return self}, function($ctx1) {$ctx1.fill(self,"basicAddCompiledMethod:",{aMethod:aMethod},smalltalk.Behavior)})}, args: ["aMethod"], source: "basicAddCompiledMethod: aMethod\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "basicNew", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return new self.fn(); return self}, function($ctx1) {$ctx1.fill(self,"basicNew",{},smalltalk.Behavior)})}, args: [], source: "basicNew\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "basicRemoveCompiledMethod:", category: 'private', fn: function (aMethod){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.removeMethod(aMethod,self); return self}, function($ctx1) {$ctx1.fill(self,"basicRemoveCompiledMethod:",{aMethod:aMethod},smalltalk.Behavior)})}, args: ["aMethod"], source: "basicRemoveCompiledMethod: aMethod\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "canUnderstand:", category: 'testing', fn: function (aSelector){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(self._methodDictionary())._keys())._includes_(_st(aSelector)._asString()))._or_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(self._superclass())._notNil())._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(self._superclass())._canUnderstand_(aSelector); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"canUnderstand:",{aSelector:aSelector},smalltalk.Behavior)})}, args: ["aSelector"], source: "canUnderstand: aSelector\x0a\x09^(self methodDictionary keys includes: aSelector asString) or: [\x0a\x09\x09self superclass notNil and: [self superclass canUnderstand: aSelector]]", messageSends: ["or:", "and:", "canUnderstand:", "superclass", "notNil", "includes:", "asString", "keys", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "comment", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._basicAt_("comment"); if(($receiver = $2) == nil || $receiver == undefined){ $1=""; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"comment",{},smalltalk.Behavior)})}, args: [], source: "comment\x0a\x09^(self basicAt: 'comment') ifNil: ['']", messageSends: ["ifNil:", "basicAt:"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "comment:", category: 'accessing', fn: function (aString){ var self=this; function $ClassCommentChanged(){return smalltalk.ClassCommentChanged||(typeof ClassCommentChanged=="undefined"?nil:ClassCommentChanged)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; self._basicAt_put_("comment",aString); $1=_st($ClassCommentChanged())._new(); _st($1)._theClass_(self); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"comment:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "comment: aString\x0a\x09self basicAt: 'comment' put: aString.\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassCommentChanged new\x0a\x09\x09\x09theClass: self;\x0a\x09\x09\x09yourself)", messageSends: ["basicAt:put:", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassCommentChanged", "SystemAnnouncer"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "commentStamp", category: 'accessing', fn: function (){ var self=this; function $ClassCommentReader(){return smalltalk.ClassCommentReader||(typeof ClassCommentReader=="undefined"?nil:ClassCommentReader)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($ClassCommentReader())._new(); _st($2)._class_(self); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"commentStamp",{},smalltalk.Behavior)})}, args: [], source: "commentStamp\x0a\x09^ClassCommentReader new\x0a\x09class: self;\x0a\x09yourself", messageSends: ["class:", "new", "yourself"], referencedClasses: ["ClassCommentReader"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "commentStamp:prior:", category: 'accessing', fn: function (aStamp,prior){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._commentStamp(); return $1; }, function($ctx1) {$ctx1.fill(self,"commentStamp:prior:",{aStamp:aStamp,prior:prior},smalltalk.Behavior)})}, args: ["aStamp", "prior"], source: "commentStamp: aStamp prior: prior\x0a\x09\x09^self commentStamp", messageSends: ["commentStamp"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "compile:", category: 'compiling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._compile_category_(aString,""); return $1; }, function($ctx1) {$ctx1.fill(self,"compile:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "compile: aString\x0a\x09^ self compile: aString category: ''", messageSends: ["compile:category:"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "compile:category:", category: 'compiling', fn: function (aString,anotherString){ var self=this; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Compiler())._new())._install_forClass_category_(aString,self,anotherString); return $1; }, function($ctx1) {$ctx1.fill(self,"compile:category:",{aString:aString,anotherString:anotherString},smalltalk.Behavior)})}, args: ["aString", "anotherString"], source: "compile: aString category: anotherString\x0a\x09^ Compiler new\x0a\x09\x09install: aString\x0a\x09\x09forClass: self\x0a\x09\x09category: anotherString", messageSends: ["install:forClass:category:", "new"], referencedClasses: ["Compiler"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "definition", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return ""; }, function($ctx1) {$ctx1.fill(self,"definition",{},smalltalk.Behavior)})}, args: [], source: "definition\x0a\x09^ ''", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "includesBehavior:", category: 'testing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self.__eq_eq(aClass))._or_((function(){ return smalltalk.withContext(function($ctx2) { return self._inheritsFrom_(aClass); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"includesBehavior:",{aClass:aClass},smalltalk.Behavior)})}, args: ["aClass"], source: "includesBehavior: aClass\x0a\x09^ self == aClass or: [\x0a\x09\x09\x09self inheritsFrom: aClass ]", messageSends: ["or:", "inheritsFrom:", "=="], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "includesSelector:", category: 'testing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._methodDictionary())._includesKey_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"includesSelector:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "includesSelector: aString\x0a\x09^ self methodDictionary includesKey: aString", messageSends: ["includesKey:", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "inheritsFrom:", category: 'testing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self._superclass(); if(($receiver = $1) == nil || $receiver == undefined){ return false; } else { $1; }; $2=_st(_st(aClass).__eq_eq(self._superclass()))._or_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._superclass())._inheritsFrom_(aClass); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $2; }, function($ctx1) {$ctx1.fill(self,"inheritsFrom:",{aClass:aClass},smalltalk.Behavior)})}, args: ["aClass"], source: "inheritsFrom: aClass\x0a\x09self superclass ifNil: [ ^ false ].\x0a\x0a\x09^ aClass == self superclass or: [ \x0a\x09\x09self superclass inheritsFrom: aClass ]", messageSends: ["ifNil:", "superclass", "or:", "inheritsFrom:", "=="], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "instanceVariableNames", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.iVarNames; return self}, function($ctx1) {$ctx1.fill(self,"instanceVariableNames",{},smalltalk.Behavior)})}, args: [], source: "instanceVariableNames\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "isBehavior", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isBehavior",{},smalltalk.Behavior)})}, args: [], source: "isBehavior\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "lookupSelector:", category: 'accessing', fn: function (selector){ var self=this; var lookupClass; return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { lookupClass=self; _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(lookupClass).__eq(nil); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { $1=_st(lookupClass)._includesSelector_(selector); if(smalltalk.assert($1)){ $2=_st(lookupClass)._methodAt_(selector); throw $early=[$2]; }; lookupClass=_st(lookupClass)._superclass(); return lookupClass; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return nil; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"lookupSelector:",{selector:selector,lookupClass:lookupClass},smalltalk.Behavior)})}, args: ["selector"], source: "lookupSelector: selector\x0a\x09\x22Look up the given selector in my methodDictionary.\x0a\x09Return the corresponding method if found.\x0a\x09Otherwise chase the superclass chain and try again.\x0a\x09Return nil if no method is found.\x22\x0a\x09\x0a\x09| lookupClass |\x0a\x09\x0a\x09lookupClass := self.\x0a\x09[ lookupClass = nil ] whileFalse: [\x0a\x09\x09(lookupClass includesSelector: selector)\x0a\x09\x09\x09\x09ifTrue: [ ^ lookupClass methodAt: selector ].\x0a\x09\x09\x09lookupClass := lookupClass superclass ].\x0a\x09^ nil", messageSends: ["whileFalse:", "ifTrue:", "methodAt:", "includesSelector:", "superclass", "="], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methodAt:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._methodDictionary())._at_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"methodAt:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "methodAt: aString\x0a\x09^ self methodDictionary at: aString", messageSends: ["at:", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methodDictionary", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var dict = smalltalk.HashedCollection._new(); var methods = self.methods; for(var i in methods) { if(methods[i].selector) { dict._at_put_(methods[i].selector, methods[i]); } }; return dict; return self}, function($ctx1) {$ctx1.fill(self,"methodDictionary",{},smalltalk.Behavior)})}, args: [], source: "methodDictionary\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methods", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._methodDictionary())._values(); return $1; }, function($ctx1) {$ctx1.fill(self,"methods",{},smalltalk.Behavior)})}, args: [], source: "methods\x0a\x09^ self methodDictionary values", messageSends: ["values", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methodsFor:", category: 'accessing', fn: function (aString){ var self=this; function $ClassCategoryReader(){return smalltalk.ClassCategoryReader||(typeof ClassCategoryReader=="undefined"?nil:ClassCategoryReader)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($ClassCategoryReader())._new(); _st($2)._class_category_(self,aString); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"methodsFor:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "methodsFor: aString\x0a\x09^ClassCategoryReader new\x0a\x09\x09class: self category: aString;\x0a\x09\x09yourself", messageSends: ["class:category:", "new", "yourself"], referencedClasses: ["ClassCategoryReader"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methodsFor:stamp:", category: 'accessing', fn: function (aString,aStamp){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._methodsFor_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"methodsFor:stamp:",{aString:aString,aStamp:aStamp},smalltalk.Behavior)})}, args: ["aString", "aStamp"], source: "methodsFor: aString stamp: aStamp\x0a\x09\x22Added for compatibility, right now ignores stamp.\x22\x0a\x09^self methodsFor: aString", messageSends: ["methodsFor:"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "methodsInProtocol:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._methodDictionary())._values())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocol()).__eq(aString); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"methodsInProtocol:",{aString:aString},smalltalk.Behavior)})}, args: ["aString"], source: "methodsInProtocol: aString\x0a\x09^ self methodDictionary values select: [ :each | each protocol = aString ]", messageSends: ["select:", "=", "protocol", "values", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "name", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.className || nil; return self}, function($ctx1) {$ctx1.fill(self,"name",{},smalltalk.Behavior)})}, args: [], source: "name\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "new", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._basicNew())._initialize(); return $1; }, function($ctx1) {$ctx1.fill(self,"new",{},smalltalk.Behavior)})}, args: [], source: "new\x0a\x09^self basicNew initialize", messageSends: ["initialize", "basicNew"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "organization", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("organization"); return $1; }, function($ctx1) {$ctx1.fill(self,"organization",{},smalltalk.Behavior)})}, args: [], source: "organization\x0a\x09^ self basicAt: 'organization'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "ownMethods", category: 'accessing', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._ownProtocols())._inject_into_(_st($OrderedCollection())._new(),(function(acc,each){ return smalltalk.withContext(function($ctx2) { return _st(acc).__comma(self._methodsInProtocol_(each)); }, function($ctx2) {$ctx2.fillBlock({acc:acc,each:each},$ctx1)})})))._sorted_((function(a,b){ return smalltalk.withContext(function($ctx2) { return _st(_st(a)._selector()).__lt_eq(_st(b)._selector()); }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"ownMethods",{},smalltalk.Behavior)})}, args: [], source: "ownMethods\x0a\x09\x22Answer the methods of the receiver that are not package extensions\x22\x0a\x0a\x09^ (self ownProtocols \x0a\x09\x09inject: OrderedCollection new\x0a\x09\x09into: [ :acc :each | acc, (self methodsInProtocol: each) ])\x0a\x09\x09\x09sorted: [ :a :b | a selector <= b selector ]", messageSends: ["sorted:", "<=", "selector", "inject:into:", "new", ",", "methodsInProtocol:", "ownProtocols"], referencedClasses: ["OrderedCollection"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "ownProtocols", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._protocols())._reject_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._match_("^\x5c*"); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"ownProtocols",{},smalltalk.Behavior)})}, args: [], source: "ownProtocols\x0a\x09\x22Answer the protocols of the receiver that are not package extensions\x22\x0a\x0a\x09^ self protocols reject: [ :each |\x0a\x09\x09each match: '^\x5c*' ]", messageSends: ["reject:", "match:", "protocols"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "protocols", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._organization())._elements())._sorted(); return $1; }, function($ctx1) {$ctx1.fill(self,"protocols",{},smalltalk.Behavior)})}, args: [], source: "protocols\x0a\x09^ self organization elements sorted", messageSends: ["sorted", "elements", "organization"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "protocolsDo:", category: 'enumerating', fn: function (aBlock){ var self=this; var methodsByCategory; function $HashedCollection(){return smalltalk.HashedCollection||(typeof HashedCollection=="undefined"?nil:HashedCollection)} function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { methodsByCategory=_st($HashedCollection())._new(); _st(_st(self._methodDictionary())._values())._do_((function(m){ return smalltalk.withContext(function($ctx2) { return _st(_st(methodsByCategory)._at_ifAbsentPut_(_st(m)._category(),(function(){ return smalltalk.withContext(function($ctx3) { return _st($Array())._new(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})))._add_(m); }, function($ctx2) {$ctx2.fillBlock({m:m},$ctx1)})})); _st(self._protocols())._do_((function(category){ return smalltalk.withContext(function($ctx2) { return _st(aBlock)._value_value_(category,_st(methodsByCategory)._at_(category)); }, function($ctx2) {$ctx2.fillBlock({category:category},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"protocolsDo:",{aBlock:aBlock,methodsByCategory:methodsByCategory},smalltalk.Behavior)})}, args: ["aBlock"], source: "protocolsDo: aBlock\x0a\x09\x22Execute aBlock for each method category with\x0a\x09its collection of methods in the sort order of category name.\x22\x0a\x0a\x09| methodsByCategory |\x0a\x09methodsByCategory := HashedCollection new.\x0a\x09self methodDictionary values do: [:m |\x0a\x09\x09(methodsByCategory at: m category ifAbsentPut: [Array new])\x0a\x09\x09\x09add: m].\x0a\x09self protocols do: [:category |\x0a\x09\x09aBlock value: category value: (methodsByCategory at: category)]", messageSends: ["new", "do:", "add:", "at:ifAbsentPut:", "category", "values", "methodDictionary", "value:value:", "at:", "protocols"], referencedClasses: ["HashedCollection", "Array"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "prototype", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.fn.prototype; return self}, function($ctx1) {$ctx1.fill(self,"prototype",{},smalltalk.Behavior)})}, args: [], source: "prototype\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "recompile", category: 'compiling', fn: function (){ var self=this; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Compiler())._new())._recompile_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"recompile",{},smalltalk.Behavior)})}, args: [], source: "recompile\x0a\x09^ Compiler new recompile: self", messageSends: ["recompile:", "new"], referencedClasses: ["Compiler"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "removeCompiledMethod:", category: 'compiling', fn: function (aMethod){ var self=this; function $MethodRemoved(){return smalltalk.MethodRemoved||(typeof MethodRemoved=="undefined"?nil:MethodRemoved)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; self._basicRemoveCompiledMethod_(aMethod); _st(self._methods())._detect_ifNone_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocol()).__eq(_st(aMethod)._protocol()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._organization())._removeElement_(_st(aMethod)._protocol()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=_st($MethodRemoved())._new(); _st($1)._method_(aMethod); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"removeCompiledMethod:",{aMethod:aMethod},smalltalk.Behavior)})}, args: ["aMethod"], source: "removeCompiledMethod: aMethod\x0a\x09self basicRemoveCompiledMethod: aMethod.\x0a\x09\x0a\x09self methods\x0a\x09\x09detect: [ :each | each protocol = aMethod protocol ]\x0a\x09\x09ifNone: [ self organization removeElement: aMethod protocol ].\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (MethodRemoved new\x0a\x09\x09\x09method: aMethod;\x0a\x09\x09\x09yourself)", messageSends: ["basicRemoveCompiledMethod:", "detect:ifNone:", "=", "protocol", "removeElement:", "organization", "methods", "announce:", "method:", "new", "yourself", "current"], referencedClasses: ["MethodRemoved", "SystemAnnouncer"] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "selectors", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._methodDictionary())._keys(); return $1; }, function($ctx1) {$ctx1.fill(self,"selectors",{},smalltalk.Behavior)})}, args: [], source: "selectors\x0a\x09^ self methodDictionary keys", messageSends: ["keys", "methodDictionary"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "subclasses", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassResponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"subclasses",{},smalltalk.Behavior)})}, args: [], source: "subclasses\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "superclass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.superclass || nil; return self}, function($ctx1) {$ctx1.fill(self,"superclass",{},smalltalk.Behavior)})}, args: [], source: "superclass\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "theMetaClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._class(); return $1; }, function($ctx1) {$ctx1.fill(self,"theMetaClass",{},smalltalk.Behavior)})}, args: [], source: "theMetaClass\x0a\x09^ self class", messageSends: ["class"], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "theNonMetaClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"theNonMetaClass",{},smalltalk.Behavior)})}, args: [], source: "theNonMetaClass\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.Behavior); smalltalk.addMethod( smalltalk.method({ selector: "withAllSubclasses", category: 'accessing', fn: function (){ var self=this; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($Array())._with_(self); _st($2)._addAll_(self._allSubclasses()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"withAllSubclasses",{},smalltalk.Behavior)})}, args: [], source: "withAllSubclasses\x0a\x09^(Array with: self) addAll: self allSubclasses; yourself", messageSends: ["addAll:", "allSubclasses", "with:", "yourself"], referencedClasses: ["Array"] }), smalltalk.Behavior); smalltalk.addClass('Class', smalltalk.Behavior, [], 'Kernel-Classes'); smalltalk.Class.comment="I am __the__ class object.\x0a\x0aMy instances are the classes of the system.\x0aClass creation is done throught a `ClassBuilder` instance."; smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1="smalltalk.".__comma(self._name()); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.Class)})}, args: [], source: "asJavascript\x0a\x09^ 'smalltalk.', self name", messageSends: [",", "name"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "category", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._package(); if(($receiver = $2) == nil || $receiver == undefined){ $1="Unclassified"; } else { $1=_st(self._package())._name(); }; return $1; }, function($ctx1) {$ctx1.fill(self,"category",{},smalltalk.Class)})}, args: [], source: "category\x0a\x09^self package ifNil: ['Unclassified'] ifNotNil: [self package name]", messageSends: ["ifNil:ifNotNil:", "name", "package"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "definition", category: 'accessing', fn: function (){ var self=this; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { var $2,$3,$4,$5,$1; $1=_st($String())._streamContents_((function(stream){ return smalltalk.withContext(function($ctx2) { $2=stream; _st($2)._nextPutAll_(_st(self._superclass())._asString()); _st($2)._nextPutAll_(" subclass: #"); _st($2)._nextPutAll_(self._name()); _st($2)._nextPutAll_(_st(_st($String())._lf()).__comma(_st($String())._tab())); $3=_st($2)._nextPutAll_("instanceVariableNames: '"); $3; _st(self._instanceVariableNames())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(stream)._nextPutAll_(each); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}),(function(){ return smalltalk.withContext(function($ctx3) { return _st(stream)._nextPutAll_(" "); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); $4=stream; _st($4)._nextPutAll_(_st("'".__comma(_st($String())._lf())).__comma(_st($String())._tab())); _st($4)._nextPutAll_("package: '"); _st($4)._nextPutAll_(self._category()); $5=_st($4)._nextPutAll_("'"); return $5; }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"definition",{},smalltalk.Class)})}, args: [], source: "definition\x0a\x09^ String streamContents: [ :stream |\x0a\x09\x09stream\x0a\x09\x09\x09nextPutAll: self superclass asString;\x0a\x09\x09\x09nextPutAll: ' subclass: #';\x0a\x09\x09\x09nextPutAll: self name;\x0a\x09\x09\x09nextPutAll: String lf, String tab;\x0a\x09\x09\x09nextPutAll: 'instanceVariableNames: '''.\x0a\x09\x09self instanceVariableNames\x0a\x09\x09\x09do: [ :each | stream nextPutAll: each ]\x0a\x09\x09\x09separatedBy: [ stream nextPutAll: ' ' ].\x0a\x09\x09stream\x0a\x09\x09\x09nextPutAll: '''', String lf, String tab;\x0a\x09\x09\x09nextPutAll: 'package: ''';\x0a\x09\x09\x09nextPutAll: self category;\x0a\x09\x09\x09nextPutAll: '''' ]", messageSends: ["streamContents:", "nextPutAll:", "asString", "superclass", "name", ",", "tab", "lf", "do:separatedBy:", "instanceVariableNames", "category"], referencedClasses: ["String"] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "isClass", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isClass",{},smalltalk.Class)})}, args: [], source: "isClass\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "package", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("pkg"); return $1; }, function($ctx1) {$ctx1.fill(self,"package",{},smalltalk.Class)})}, args: [], source: "package\x0a\x09^ self basicAt: 'pkg'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "package:", category: 'accessing', fn: function (aPackage){ var self=this; var oldPackage; function $ClassMoved(){return smalltalk.ClassMoved||(typeof ClassMoved=="undefined"?nil:ClassMoved)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=_st(self._package()).__eq(aPackage); if(smalltalk.assert($1)){ $2=self; return $2; }; oldPackage=self._package(); self._basicAt_put_("pkg",aPackage); _st(_st(oldPackage)._organization())._removeElement_(self); _st(_st(aPackage)._organization())._addElement_(self); $3=_st($ClassMoved())._new(); _st($3)._theClass_(self); _st($3)._oldPackage_(oldPackage); $4=_st($3)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($4); return self}, function($ctx1) {$ctx1.fill(self,"package:",{aPackage:aPackage,oldPackage:oldPackage},smalltalk.Class)})}, args: ["aPackage"], source: "package: aPackage\x0a\x09| oldPackage |\x0a\x09\x0a\x09self package = aPackage ifTrue: [ ^ self ].\x0a\x09\x0a\x09oldPackage := self package.\x0a\x09\x0a\x09self basicAt: 'pkg' put: aPackage.\x0a\x09oldPackage organization removeElement: self.\x0a\x09aPackage organization addElement: self.\x0a\x0a\x09SystemAnnouncer current announce: (ClassMoved new\x0a\x09\x09theClass: self;\x0a\x09\x09oldPackage: oldPackage;\x0a\x09\x09yourself)", messageSends: ["ifTrue:", "=", "package", "basicAt:put:", "removeElement:", "organization", "addElement:", "announce:", "theClass:", "new", "oldPackage:", "yourself", "current"], referencedClasses: ["ClassMoved", "SystemAnnouncer"] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_(self._name()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Class)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: self name", messageSends: ["nextPutAll:", "name"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "rename:", category: 'accessing', fn: function (aString){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { _st(_st($ClassBuilder())._new())._renameClass_to_(self,aString); return self}, function($ctx1) {$ctx1.fill(self,"rename:",{aString:aString},smalltalk.Class)})}, args: ["aString"], source: "rename: aString\x0a\x09ClassBuilder new renameClass: self to: aString", messageSends: ["renameClass:to:", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:", category: 'class creation', fn: function (aString,anotherString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._subclass_instanceVariableNames_package_(aString,anotherString,nil); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:",{aString:aString,anotherString:anotherString},smalltalk.Class)})}, args: ["aString", "anotherString"], source: "subclass: aString instanceVariableNames: anotherString\x0a\x09\x22Kept for compatibility.\x22\x0a\x09^self subclass: aString instanceVariableNames: anotherString package: nil", messageSends: ["subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:category:", category: 'class creation', fn: function (aString,aString2,aString3){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._deprecatedAPI(); $1=self._subclass_instanceVariableNames_package_(aString,aString2,aString3); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:category:",{aString:aString,aString2:aString2,aString3:aString3},smalltalk.Class)})}, args: ["aString", "aString2", "aString3"], source: "subclass: aString instanceVariableNames: aString2 category: aString3\x0a\x09\x22Kept for compatibility.\x22\x0a\x09self deprecatedAPI.\x0a\x09^self subclass: aString instanceVariableNames: aString2 package: aString3", messageSends: ["deprecatedAPI", "subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:", category: 'class creation', fn: function (aString,aString2,classVars,pools,aString3){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._subclass_instanceVariableNames_package_(aString,aString2,aString3); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:classVariableNames:poolDictionaries:category:",{aString:aString,aString2:aString2,classVars:classVars,pools:pools,aString3:aString3},smalltalk.Class)})}, args: ["aString", "aString2", "classVars", "pools", "aString3"], source: "subclass: aString instanceVariableNames: aString2 classVariableNames: classVars poolDictionaries: pools category: aString3\x0a\x09\x22Just ignore class variables and pools. Added for compatibility.\x22\x0a\x09^self subclass: aString instanceVariableNames: aString2 package: aString3", messageSends: ["subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "subclass:instanceVariableNames:package:", category: 'class creation', fn: function (aString,aString2,aString3){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($ClassBuilder())._new())._superclass_subclass_instanceVariableNames_package_(self,_st(aString)._asString(),aString2,aString3); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:instanceVariableNames:package:",{aString:aString,aString2:aString2,aString3:aString3},smalltalk.Class)})}, args: ["aString", "aString2", "aString3"], source: "subclass: aString instanceVariableNames: aString2 package: aString3\x0a\x09^ClassBuilder new\x0a\x09\x09superclass: self subclass: aString asString instanceVariableNames: aString2 package: aString3", messageSends: ["superclass:subclass:instanceVariableNames:package:", "asString", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Class); smalltalk.addMethod( smalltalk.method({ selector: "subclasses", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.subclasses._copy(); return self}, function($ctx1) {$ctx1.fill(self,"subclasses",{},smalltalk.Class)})}, args: [], source: "subclasses\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Class); smalltalk.addClass('Metaclass', smalltalk.Behavior, [], 'Kernel-Classes'); smalltalk.Metaclass.comment="I am the root of the class hierarchy.\x0a\x0aMy instances are metaclasses, one for each real class, and have a single instance, which they hold onto: the class that they are the metaclass of."; smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("smalltalk.".__comma(_st(self._instanceClass())._name())).__comma(".klass"); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.Metaclass)})}, args: [], source: "asJavascript\x0a\x09^ 'smalltalk.', self instanceClass name, '.klass'", messageSends: [",", "name", "instanceClass"], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "definition", category: 'accessing', fn: function (){ var self=this; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $1=_st($String())._streamContents_((function(stream){ return smalltalk.withContext(function($ctx2) { $2=stream; _st($2)._nextPutAll_(self._asString()); $3=_st($2)._nextPutAll_(" instanceVariableNames: '"); $3; _st(self._instanceVariableNames())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(stream)._nextPutAll_(each); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}),(function(){ return smalltalk.withContext(function($ctx3) { return _st(stream)._nextPutAll_(" "); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); return _st(stream)._nextPutAll_("'"); }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"definition",{},smalltalk.Metaclass)})}, args: [], source: "definition\x0a\x09^ String streamContents: [ :stream |\x0a\x09\x09stream\x0a\x09\x09\x09nextPutAll: self asString;\x0a\x09\x09\x09nextPutAll: ' instanceVariableNames: '''.\x0a\x09\x09self instanceVariableNames\x0a\x09\x09\x09do: [ :each | stream nextPutAll: each ]\x0a\x09\x09\x09separatedBy: [ stream nextPutAll: ' ' ].\x0a\x09\x09stream nextPutAll: '''' ]", messageSends: ["streamContents:", "nextPutAll:", "asString", "do:separatedBy:", "instanceVariableNames"], referencedClasses: ["String"] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "instanceClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.instanceClass; return self}, function($ctx1) {$ctx1.fill(self,"instanceClass",{},smalltalk.Metaclass)})}, args: [], source: "instanceClass\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "instanceVariableNames:", category: 'accessing', fn: function (aCollection){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { _st(_st($ClassBuilder())._new())._class_instanceVariableNames_(self,aCollection); return self}, function($ctx1) {$ctx1.fill(self,"instanceVariableNames:",{aCollection:aCollection},smalltalk.Metaclass)})}, args: ["aCollection"], source: "instanceVariableNames: aCollection\x0a\x09ClassBuilder new\x0a\x09\x09class: self instanceVariableNames: aCollection", messageSends: ["class:instanceVariableNames:", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "isMetaclass", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isMetaclass",{},smalltalk.Metaclass)})}, args: [], source: "isMetaclass\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aStream; _st($1)._nextPutAll_(_st(self._instanceClass())._name()); $2=_st($1)._nextPutAll_(" class"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Metaclass)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream\x0a\x09\x09nextPutAll: self instanceClass name;\x0a\x09\x09nextPutAll: ' class'", messageSends: ["nextPutAll:", "name", "instanceClass"], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "subclasses", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(self._instanceClass())._subclasses())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._isMetaclass())._not(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._theMetaClass(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"subclasses",{},smalltalk.Metaclass)})}, args: [], source: "subclasses\x0a\x09^ (self instanceClass subclasses \x0a\x09\x09select: [ :each | each isMetaclass not ])\x0a\x09\x09collect: [ :each | each theMetaClass ]", messageSends: ["collect:", "theMetaClass", "select:", "not", "isMetaclass", "subclasses", "instanceClass"], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "theMetaClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"theMetaClass",{},smalltalk.Metaclass)})}, args: [], source: "theMetaClass\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addMethod( smalltalk.method({ selector: "theNonMetaClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._instanceClass(); return $1; }, function($ctx1) {$ctx1.fill(self,"theNonMetaClass",{},smalltalk.Metaclass)})}, args: [], source: "theNonMetaClass\x0a\x09^ self instanceClass", messageSends: ["instanceClass"], referencedClasses: [] }), smalltalk.Metaclass); smalltalk.addClass('ClassBuilder', smalltalk.Object, [], 'Kernel-Classes'); smalltalk.ClassBuilder.comment="I am responsible for compiling new classes or modifying existing classes in the system.\x0a\x0aRather than using me directly to compile a class, use `Class >> subclass:instanceVariableNames:package:`."; smalltalk.addMethod( smalltalk.method({ selector: "addSubclassOf:named:instanceVariableNames:package:", category: 'class definition', fn: function (aClass,className,aCollection,packageName){ var self=this; var theClass,thePackage; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; theClass=_st(_st($Smalltalk())._current())._at_(className); thePackage=self._createPackageNamed_(packageName); $1=theClass; if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { _st(theClass)._package_(thePackage); $2=_st(_st(theClass)._superclass()).__eq_eq(aClass); if(! smalltalk.assert($2)){ $3=self._migrateClassNamed_superclass_instanceVariableNames_package_(className,aClass,aCollection,packageName); return $3; }; }; $4=self._basicAddSubclassOf_named_instanceVariableNames_package_(aClass,className,aCollection,packageName); return $4; }, function($ctx1) {$ctx1.fill(self,"addSubclassOf:named:instanceVariableNames:package:",{aClass:aClass,className:className,aCollection:aCollection,packageName:packageName,theClass:theClass,thePackage:thePackage},smalltalk.ClassBuilder)})}, args: ["aClass", "className", "aCollection", "packageName"], source: "addSubclassOf: aClass named: className instanceVariableNames: aCollection package: packageName\x0a\x09| theClass thePackage |\x0a\x09\x0a\x09theClass := Smalltalk current at: className.\x0a\x09thePackage := self createPackageNamed: packageName.\x0a\x09\x0a\x09theClass ifNotNil: [\x0a\x09\x09theClass package: thePackage.\x0a\x09\x09theClass superclass == aClass ifFalse: [\x0a\x09\x09\x09^ self\x0a\x09\x09\x09\x09migrateClassNamed: className\x0a\x09\x09\x09\x09superclass: aClass\x0a\x09\x09\x09\x09instanceVariableNames: aCollection\x0a\x09\x09\x09\x09package: packageName ] ].\x0a\x09\x09\x0a\x09^ self\x0a\x09\x09basicAddSubclassOf: aClass\x0a\x09\x09named: className\x0a\x09\x09instanceVariableNames: aCollection\x0a\x09\x09package: packageName", messageSends: ["at:", "current", "createPackageNamed:", "ifNotNil:", "package:", "ifFalse:", "migrateClassNamed:superclass:instanceVariableNames:package:", "==", "superclass", "basicAddSubclassOf:named:instanceVariableNames:package:"], referencedClasses: ["Smalltalk"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicAddSubclassOf:named:instanceVariableNames:package:", category: 'private', fn: function (aClass,aString,aCollection,packageName){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.addClass(aString, aClass, aCollection, packageName); return smalltalk[aString] ; return self}, function($ctx1) {$ctx1.fill(self,"basicAddSubclassOf:named:instanceVariableNames:package:",{aClass:aClass,aString:aString,aCollection:aCollection,packageName:packageName},smalltalk.ClassBuilder)})}, args: ["aClass", "aString", "aCollection", "packageName"], source: "basicAddSubclassOf: aClass named: aString instanceVariableNames: aCollection package: packageName\x0a\x09<\x0a\x09\x09smalltalk.addClass(aString, aClass, aCollection, packageName);\x0a\x09\x09return smalltalk[aString]\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicClass:instanceVariableNames:", category: 'private', fn: function (aClass,aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._basicClass_instanceVariables_(aClass,self._instanceVariableNamesFor_(aString)); return self}, function($ctx1) {$ctx1.fill(self,"basicClass:instanceVariableNames:",{aClass:aClass,aString:aString},smalltalk.ClassBuilder)})}, args: ["aClass", "aString"], source: "basicClass: aClass instanceVariableNames: aString\x0a\x09self basicClass: aClass instanceVariables: (self instanceVariableNamesFor: aString)", messageSends: ["basicClass:instanceVariables:", "instanceVariableNamesFor:"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicClass:instanceVariables:", category: 'private', fn: function (aClass,aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aClass)._isMetaclass(); if(! smalltalk.assert($1)){ self._error_(_st(_st(aClass)._name()).__comma(" is not a metaclass")); }; _st(aClass)._basicAt_put_("iVarNames",aCollection); return self}, function($ctx1) {$ctx1.fill(self,"basicClass:instanceVariables:",{aClass:aClass,aCollection:aCollection},smalltalk.ClassBuilder)})}, args: ["aClass", "aCollection"], source: "basicClass: aClass instanceVariables: aCollection\x0a\x0a\x09aClass isMetaclass ifFalse: [self error: aClass name, ' is not a metaclass'].\x0a\x09aClass basicAt: 'iVarNames' put: aCollection", messageSends: ["ifFalse:", "error:", ",", "name", "isMetaclass", "basicAt:put:"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicRemoveClass:", category: 'private', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.removeClass(aClass); return self}, function($ctx1) {$ctx1.fill(self,"basicRemoveClass:",{aClass:aClass},smalltalk.ClassBuilder)})}, args: ["aClass"], source: "basicRemoveClass: aClass\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicRenameClass:to:", category: 'private', fn: function (aClass,aString){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk[aString] = aClass; delete smalltalk[aClass.className]; aClass.className = aString; ; return self}, function($ctx1) {$ctx1.fill(self,"basicRenameClass:to:",{aClass:aClass,aString:aString},smalltalk.ClassBuilder)})}, args: ["aClass", "aString"], source: "basicRenameClass: aClass to: aString\x0a\x09<\x0a\x09\x09smalltalk[aString] = aClass;\x0a\x09\x09delete smalltalk[aClass.className];\x0a\x09\x09aClass.className = aString;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "basicSwapClassNames:with:", category: 'private', fn: function (aClass,anotherClass){ var self=this; return smalltalk.withContext(function($ctx1) { var tmp = aClass.className; aClass.className = anotherClass.className; anotherClass.className = tmp; ; return self}, function($ctx1) {$ctx1.fill(self,"basicSwapClassNames:with:",{aClass:aClass,anotherClass:anotherClass},smalltalk.ClassBuilder)})}, args: ["aClass", "anotherClass"], source: "basicSwapClassNames: aClass with: anotherClass\x0a\x09<\x0a\x09\x09var tmp = aClass.className;\x0a\x09\x09aClass.className = anotherClass.className;\x0a\x09\x09anotherClass.className = tmp;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "class:instanceVariableNames:", category: 'class definition', fn: function (aClass,ivarNames){ var self=this; function $ClassDefinitionChanged(){return smalltalk.ClassDefinitionChanged||(typeof ClassDefinitionChanged=="undefined"?nil:ClassDefinitionChanged)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; self._basicClass_instanceVariableNames_(aClass,ivarNames); self._setupClass_(aClass); $1=_st($ClassDefinitionChanged())._new(); _st($1)._theClass_(aClass); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"class:instanceVariableNames:",{aClass:aClass,ivarNames:ivarNames},smalltalk.ClassBuilder)})}, args: ["aClass", "ivarNames"], source: "class: aClass instanceVariableNames: ivarNames\x0a\x09self basicClass: aClass instanceVariableNames: ivarNames.\x0a\x09self setupClass: aClass.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassDefinitionChanged new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)", messageSends: ["basicClass:instanceVariableNames:", "setupClass:", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassDefinitionChanged", "SystemAnnouncer"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "copyClass:named:", category: 'copying', fn: function (aClass,className){ var self=this; var newClass; function $ClassAdded(){return smalltalk.ClassAdded||(typeof ClassAdded=="undefined"?nil:ClassAdded)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; newClass=self._addSubclassOf_named_instanceVariableNames_package_(_st(aClass)._superclass(),className,_st(aClass)._instanceVariableNames(),_st(_st(aClass)._package())._name()); self._copyClass_to_(aClass,newClass); $1=_st($ClassAdded())._new(); _st($1)._theClass_(newClass); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); $3=newClass; return $3; }, function($ctx1) {$ctx1.fill(self,"copyClass:named:",{aClass:aClass,className:className,newClass:newClass},smalltalk.ClassBuilder)})}, args: ["aClass", "className"], source: "copyClass: aClass named: className\x0a\x09| newClass |\x0a\x0a\x09newClass := self\x0a\x09\x09addSubclassOf: aClass superclass\x0a\x09\x09named: className\x0a\x09\x09instanceVariableNames: aClass instanceVariableNames\x0a\x09\x09package: aClass package name.\x0a\x0a\x09self copyClass: aClass to: newClass.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassAdded new\x0a\x09\x09\x09theClass: newClass;\x0a\x09\x09\x09yourself).\x0a\x09\x0a\x09^newClass", messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "superclass", "instanceVariableNames", "name", "package", "copyClass:to:", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassAdded", "SystemAnnouncer"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "copyClass:to:", category: 'copying', fn: function (aClass,anotherClass){ var self=this; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { _st(anotherClass)._comment_(_st(aClass)._comment()); _st(_st(_st(aClass)._methodDictionary())._values())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st($Compiler())._new())._install_forClass_category_(_st(each)._source(),anotherClass,_st(each)._category()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); self._basicClass_instanceVariables_(_st(anotherClass)._class(),_st(_st(aClass)._class())._instanceVariableNames()); _st(_st(_st(_st(aClass)._class())._methodDictionary())._values())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st($Compiler())._new())._install_forClass_category_(_st(each)._source(),_st(anotherClass)._class(),_st(each)._category()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); self._setupClass_(anotherClass); return self}, function($ctx1) {$ctx1.fill(self,"copyClass:to:",{aClass:aClass,anotherClass:anotherClass},smalltalk.ClassBuilder)})}, args: ["aClass", "anotherClass"], source: "copyClass: aClass to: anotherClass\x0a\x0a\x09anotherClass comment: aClass comment.\x0a\x0a\x09aClass methodDictionary values do: [ :each |\x0a\x09\x09Compiler new install: each source forClass: anotherClass category: each category ].\x0a\x0a\x09self basicClass: anotherClass class instanceVariables: aClass class instanceVariableNames.\x0a\x0a\x09aClass class methodDictionary values do: [ :each |\x0a\x09\x09Compiler new install: each source forClass: anotherClass class category: each category ].\x0a\x0a\x09self setupClass: anotherClass", messageSends: ["comment:", "comment", "do:", "install:forClass:category:", "source", "category", "new", "values", "methodDictionary", "basicClass:instanceVariables:", "class", "instanceVariableNames", "setupClass:"], referencedClasses: ["Compiler"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "createPackageNamed:", category: 'private', fn: function (aString){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $Package(){return smalltalk.Package||(typeof Package=="undefined"?nil:Package)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Package())._named_ifAbsent_(aString,(function(){ return smalltalk.withContext(function($ctx2) { return _st(_st($Smalltalk())._current())._createPackage_(aString); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"createPackageNamed:",{aString:aString},smalltalk.ClassBuilder)})}, args: ["aString"], source: "createPackageNamed: aString\x0a\x09^ Package named: aString ifAbsent: [\x0a\x09\x09Smalltalk current createPackage: aString ]", messageSends: ["named:ifAbsent:", "createPackage:", "current"], referencedClasses: ["Smalltalk", "Package"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "installMethod:forClass:category:", category: 'method definition', fn: function (aCompiledMethod,aBehavior,aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(aCompiledMethod)._category_(aString); _st(aBehavior)._addCompiledMethod_(aCompiledMethod); self._setupClass_(aBehavior); $1=aCompiledMethod; return $1; }, function($ctx1) {$ctx1.fill(self,"installMethod:forClass:category:",{aCompiledMethod:aCompiledMethod,aBehavior:aBehavior,aString:aString},smalltalk.ClassBuilder)})}, args: ["aCompiledMethod", "aBehavior", "aString"], source: "installMethod: aCompiledMethod forClass: aBehavior category: aString\x0a\x09aCompiledMethod category: aString.\x0a\x09aBehavior addCompiledMethod: aCompiledMethod.\x0a\x09self setupClass: aBehavior.\x0a\x09^aCompiledMethod", messageSends: ["category:", "addCompiledMethod:", "setupClass:"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "instanceVariableNamesFor:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(aString)._tokenize_(" "))._reject_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._isEmpty(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"instanceVariableNamesFor:",{aString:aString},smalltalk.ClassBuilder)})}, args: ["aString"], source: "instanceVariableNamesFor: aString\x0a\x09^(aString tokenize: ' ') reject: [ :each | each isEmpty ]", messageSends: ["reject:", "isEmpty", "tokenize:"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "migrateClass:superclass:", category: 'class migration', fn: function (aClass,anotherClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._migrateClassNamed_superclass_instanceVariableNames_package_(_st(aClass)._name(),anotherClass,_st(aClass)._instanceVariableNames(),_st(_st(aClass)._package())._name()); return $1; }, function($ctx1) {$ctx1.fill(self,"migrateClass:superclass:",{aClass:aClass,anotherClass:anotherClass},smalltalk.ClassBuilder)})}, args: ["aClass", "anotherClass"], source: "migrateClass: aClass superclass: anotherClass\x0a\x09^ self\x0a\x09\x09migrateClassNamed: aClass name\x0a\x09\x09superclass: anotherClass\x0a\x09\x09instanceVariableNames: aClass instanceVariableNames\x0a\x09\x09package: aClass package name", messageSends: ["migrateClassNamed:superclass:instanceVariableNames:package:", "name", "instanceVariableNames", "package"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "migrateClassNamed:superclass:instanceVariableNames:package:", category: 'class migration', fn: function (className,aClass,aCollection,packageName){ var self=this; var oldClass,newClass,tmp; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $Error(){return smalltalk.Error||(typeof Error=="undefined"?nil:Error)} function $ClassMigrated(){return smalltalk.ClassMigrated||(typeof ClassMigrated=="undefined"?nil:ClassMigrated)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7; tmp="new*".__comma(className); oldClass=_st(_st($Smalltalk())._current())._at_(className); newClass=self._addSubclassOf_named_instanceVariableNames_package_(aClass,tmp,aCollection,packageName); self._basicSwapClassNames_with_(oldClass,newClass); _st((function(){ return smalltalk.withContext(function($ctx2) { return self._copyClass_to_(oldClass,newClass); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._on_do_($Error(),(function(exception){ return smalltalk.withContext(function($ctx2) { $1=self; _st($1)._basicSwapClassNames_with_(oldClass,newClass); $2=_st($1)._basicRemoveClass_(newClass); $2; return _st(exception)._signal(); }, function($ctx2) {$ctx2.fillBlock({exception:exception},$ctx1)})})); $3=self; _st($3)._rawRenameClass_to_(oldClass,tmp); $4=_st($3)._rawRenameClass_to_(newClass,className); _st(_st(oldClass)._subclasses())._do_displayingProgress_((function(each){ return smalltalk.withContext(function($ctx2) { return self._migrateClass_superclass_(each,newClass); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),_st("Recompiling ".__comma(_st(newClass)._name())).__comma("...")); self._basicRemoveClass_(oldClass); $5=_st($ClassMigrated())._new(); _st($5)._theClass_(newClass); _st($5)._oldClass_(oldClass); $6=_st($5)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($6); $7=newClass; return $7; }, function($ctx1) {$ctx1.fill(self,"migrateClassNamed:superclass:instanceVariableNames:package:",{className:className,aClass:aClass,aCollection:aCollection,packageName:packageName,oldClass:oldClass,newClass:newClass,tmp:tmp},smalltalk.ClassBuilder)})}, args: ["className", "aClass", "aCollection", "packageName"], source: "migrateClassNamed: className superclass: aClass instanceVariableNames: aCollection package: packageName\x0a\x09| oldClass newClass tmp |\x0a\x09\x0a\x09tmp := 'new*', className.\x0a\x09oldClass := Smalltalk current at: className.\x0a\x09\x0a\x09newClass := self\x0a\x09\x09addSubclassOf: aClass\x0a\x09\x09named: tmp\x0a\x09\x09instanceVariableNames: aCollection\x0a\x09\x09package: packageName.\x0a\x0a\x09self basicSwapClassNames: oldClass with: newClass.\x0a\x0a\x09[ self copyClass: oldClass to: newClass ]\x0a\x09\x09on: Error\x0a\x09\x09do: [ :exception |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09basicSwapClassNames: oldClass with: newClass;\x0a\x09\x09\x09\x09basicRemoveClass: newClass.\x0a\x09\x09\x09exception signal ].\x0a\x0a\x09self\x0a\x09\x09rawRenameClass: oldClass to: tmp;\x0a\x09\x09rawRenameClass: newClass to: className.\x0a\x0a\x09oldClass subclasses \x0a\x09\x09do: [ :each | self migrateClass: each superclass: newClass ]\x0a\x09\x09displayingProgress: 'Recompiling ', newClass name, '...'.\x0a\x0a\x09self basicRemoveClass: oldClass.\x0a\x09\x0a\x09SystemAnnouncer current announce: (ClassMigrated new\x0a\x09\x09theClass: newClass;\x0a\x09\x09oldClass: oldClass;\x0a\x09\x09yourself).\x0a\x09\x0a\x09^newClass", messageSends: [",", "at:", "current", "addSubclassOf:named:instanceVariableNames:package:", "basicSwapClassNames:with:", "on:do:", "basicRemoveClass:", "signal", "copyClass:to:", "rawRenameClass:to:", "do:displayingProgress:", "migrateClass:superclass:", "name", "subclasses", "announce:", "theClass:", "new", "oldClass:", "yourself"], referencedClasses: ["Smalltalk", "Error", "ClassMigrated", "SystemAnnouncer"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "rawRenameClass:to:", category: 'private', fn: function (aClass,aString){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk[aString] = aClass; ; return self}, function($ctx1) {$ctx1.fill(self,"rawRenameClass:to:",{aClass:aClass,aString:aString},smalltalk.ClassBuilder)})}, args: ["aClass", "aString"], source: "rawRenameClass: aClass to: aString\x0a\x09<\x0a\x09\x09smalltalk[aString] = aClass;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "renameClass:to:", category: 'class migration', fn: function (aClass,className){ var self=this; function $ClassRenamed(){return smalltalk.ClassRenamed||(typeof ClassRenamed=="undefined"?nil:ClassRenamed)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; self._basicRenameClass_to_(aClass,className); _st(aClass)._recompile(); $1=_st($ClassRenamed())._new(); _st($1)._theClass_(aClass); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"renameClass:to:",{aClass:aClass,className:className},smalltalk.ClassBuilder)})}, args: ["aClass", "className"], source: "renameClass: aClass to: className\x0a\x09self basicRenameClass: aClass to: className.\x0a\x09\x0a\x09\x22Recompile the class to fix potential issues with super sends\x22\x0a\x09aClass recompile.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassRenamed new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)", messageSends: ["basicRenameClass:to:", "recompile", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassRenamed", "SystemAnnouncer"] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "setupClass:", category: 'public', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.init(aClass);; return self}, function($ctx1) {$ctx1.fill(self,"setupClass:",{aClass:aClass},smalltalk.ClassBuilder)})}, args: ["aClass"], source: "setupClass: aClass\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "superclass:subclass:", category: 'class definition', fn: function (aClass,className){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._superclass_subclass_instanceVariableNames_package_(aClass,className,"",nil); return $1; }, function($ctx1) {$ctx1.fill(self,"superclass:subclass:",{aClass:aClass,className:className},smalltalk.ClassBuilder)})}, args: ["aClass", "className"], source: "superclass: aClass subclass: className\x0a\x09^self superclass: aClass subclass: className instanceVariableNames: '' package: nil", messageSends: ["superclass:subclass:instanceVariableNames:package:"], referencedClasses: [] }), smalltalk.ClassBuilder); smalltalk.addMethod( smalltalk.method({ selector: "superclass:subclass:instanceVariableNames:package:", category: 'class definition', fn: function (aClass,className,ivarNames,packageName){ var self=this; var newClass; function $ClassAdded(){return smalltalk.ClassAdded||(typeof ClassAdded=="undefined"?nil:ClassAdded)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$6,$5,$7,$8,$9; $1=self; $2=aClass; $3=className; $4=self._instanceVariableNamesFor_(ivarNames); $6=packageName; if(($receiver = $6) == nil || $receiver == undefined){ $5="unclassified"; } else { $5=$6; }; newClass=_st($1)._addSubclassOf_named_instanceVariableNames_package_($2,$3,$4,$5); self._setupClass_(newClass); $7=_st($ClassAdded())._new(); _st($7)._theClass_(newClass); $8=_st($7)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($8); $9=newClass; return $9; }, function($ctx1) {$ctx1.fill(self,"superclass:subclass:instanceVariableNames:package:",{aClass:aClass,className:className,ivarNames:ivarNames,packageName:packageName,newClass:newClass},smalltalk.ClassBuilder)})}, args: ["aClass", "className", "ivarNames", "packageName"], source: "superclass: aClass subclass: className instanceVariableNames: ivarNames package: packageName\x0a\x09| newClass |\x0a\x09\x0a\x09newClass := self addSubclassOf: aClass\x0a\x09\x09named: className instanceVariableNames: (self instanceVariableNamesFor: ivarNames)\x0a\x09\x09package: (packageName ifNil: ['unclassified']).\x0a\x09self setupClass: newClass.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassAdded new\x0a\x09\x09\x09theClass: newClass;\x0a\x09\x09\x09yourself).\x0a\x09\x0a\x09^newClass", messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "instanceVariableNamesFor:", "ifNil:", "setupClass:", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassAdded", "SystemAnnouncer"] }), smalltalk.ClassBuilder); smalltalk.addClass('ClassCategoryReader', smalltalk.Object, ['class', 'category'], 'Kernel-Classes'); smalltalk.ClassCategoryReader.comment="I provide a mechanism for retrieving class descriptions stored on a file in the Smalltalk chunk format."; smalltalk.addMethod( smalltalk.method({ selector: "class:category:", category: 'accessing', fn: function (aClass,aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@class"]=aClass; self["@category"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"class:category:",{aClass:aClass,aString:aString},smalltalk.ClassCategoryReader)})}, args: ["aClass", "aString"], source: "class: aClass category: aString\x0a\x09class := aClass.\x0a\x09category := aString", messageSends: [], referencedClasses: [] }), smalltalk.ClassCategoryReader); smalltalk.addMethod( smalltalk.method({ selector: "compileMethod:", category: 'private', fn: function (aString){ var self=this; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { _st(_st($Compiler())._new())._install_forClass_category_(aString,self["@class"],self["@category"]); return self}, function($ctx1) {$ctx1.fill(self,"compileMethod:",{aString:aString},smalltalk.ClassCategoryReader)})}, args: ["aString"], source: "compileMethod: aString\x0a\x09Compiler new install: aString forClass: class category: category", messageSends: ["install:forClass:category:", "new"], referencedClasses: ["Compiler"] }), smalltalk.ClassCategoryReader); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.ClassCategoryReader.superclass.fn.prototype._initialize.apply(_st(self), []); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ClassCategoryReader)})}, args: [], source: "initialize\x0a\x09super initialize.", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.ClassCategoryReader); smalltalk.addMethod( smalltalk.method({ selector: "scanFrom:", category: 'fileIn', fn: function (aChunkParser){ var self=this; var chunk; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { _st((function(){ return smalltalk.withContext(function($ctx2) { chunk=_st(aChunkParser)._nextChunk(); chunk; return _st(chunk)._isEmpty(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { return self._compileMethod_(chunk); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(_st($ClassBuilder())._new())._setupClass_(self["@class"]); return self}, function($ctx1) {$ctx1.fill(self,"scanFrom:",{aChunkParser:aChunkParser,chunk:chunk},smalltalk.ClassCategoryReader)})}, args: ["aChunkParser"], source: "scanFrom: aChunkParser\x0a\x09| chunk |\x0a\x09[chunk := aChunkParser nextChunk.\x0a\x09chunk isEmpty] whileFalse: [\x0a\x09\x09self compileMethod: chunk].\x0a\x09ClassBuilder new setupClass: class", messageSends: ["whileFalse:", "compileMethod:", "nextChunk", "isEmpty", "setupClass:", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.ClassCategoryReader); smalltalk.addClass('ClassCommentReader', smalltalk.Object, ['class'], 'Kernel-Classes'); smalltalk.ClassCommentReader.comment="I provide a mechanism for retrieving class comments stored on a file.\x0a\x0aSee also `ClassCategoryReader`."; smalltalk.addMethod( smalltalk.method({ selector: "class:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@class"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"class:",{aClass:aClass},smalltalk.ClassCommentReader)})}, args: ["aClass"], source: "class: aClass\x0a\x09class := aClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassCommentReader); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.ClassCommentReader.superclass.fn.prototype._initialize.apply(_st(self), []); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ClassCommentReader)})}, args: [], source: "initialize\x0a\x09super initialize.", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.ClassCommentReader); smalltalk.addMethod( smalltalk.method({ selector: "scanFrom:", category: 'fileIn', fn: function (aChunkParser){ var self=this; var chunk; return smalltalk.withContext(function($ctx1) { var $1; chunk=_st(aChunkParser)._nextChunk(); $1=_st(chunk)._isEmpty(); if(! smalltalk.assert($1)){ self._setComment_(chunk); }; return self}, function($ctx1) {$ctx1.fill(self,"scanFrom:",{aChunkParser:aChunkParser,chunk:chunk},smalltalk.ClassCommentReader)})}, args: ["aChunkParser"], source: "scanFrom: aChunkParser\x0a\x09| chunk |\x0a\x09chunk := aChunkParser nextChunk.\x0a\x09chunk isEmpty ifFalse: [\x0a\x09\x09self setComment: chunk].", messageSends: ["nextChunk", "ifFalse:", "setComment:", "isEmpty"], referencedClasses: [] }), smalltalk.ClassCommentReader); smalltalk.addMethod( smalltalk.method({ selector: "setComment:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@class"])._comment_(aString); return self}, function($ctx1) {$ctx1.fill(self,"setComment:",{aString:aString},smalltalk.ClassCommentReader)})}, args: ["aString"], source: "setComment: aString\x0a\x09class comment: aString", messageSends: ["comment:"], referencedClasses: [] }), smalltalk.ClassCommentReader); smalltalk.addClass('ClassSorterNode', smalltalk.Object, ['theClass', 'level', 'nodes'], 'Kernel-Classes'); smalltalk.ClassSorterNode.comment="I provide an algorithm for sorting classes alphabetically.\x0a\x0aSee [Issue #143](https://github.com/amber-smalltalk/amber/issues/143) on GitHub."; smalltalk.addMethod( smalltalk.method({ selector: "getNodesFrom:", category: 'accessing', fn: function (aCollection){ var self=this; var children,others; function $ClassSorterNode(){return smalltalk.ClassSorterNode||(typeof ClassSorterNode=="undefined"?nil:ClassSorterNode)} return smalltalk.withContext(function($ctx1) { var $1; children=[]; others=[]; _st(aCollection)._do_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st(_st(each)._superclass()).__eq(self._theClass()); if(smalltalk.assert($1)){ return _st(children)._add_(each); } else { return _st(others)._add_(each); }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); self["@nodes"]=_st(children)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st($ClassSorterNode())._on_classes_level_(each,others,_st(self._level()).__plus((1))); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"getNodesFrom:",{aCollection:aCollection,children:children,others:others},smalltalk.ClassSorterNode)})}, args: ["aCollection"], source: "getNodesFrom: aCollection\x0a\x09| children others |\x0a\x09children := #().\x0a\x09others := #().\x0a\x09aCollection do: [:each |\x0a\x09\x09(each superclass = self theClass)\x0a\x09\x09\x09ifTrue: [children add: each]\x0a\x09\x09\x09ifFalse: [others add: each]].\x0a\x09nodes:= children collect: [:each |\x0a\x09\x09ClassSorterNode on: each classes: others level: self level + 1]", messageSends: ["do:", "ifTrue:ifFalse:", "add:", "=", "theClass", "superclass", "collect:", "on:classes:level:", "+", "level"], referencedClasses: ["ClassSorterNode"] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "level", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@level"]; return $1; }, function($ctx1) {$ctx1.fill(self,"level",{},smalltalk.ClassSorterNode)})}, args: [], source: "level\x0a\x09^level", messageSends: [], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "level:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@level"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"level:",{anInteger:anInteger},smalltalk.ClassSorterNode)})}, args: ["anInteger"], source: "level: anInteger\x0a\x09level := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "nodes", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@nodes"]; return $1; }, function($ctx1) {$ctx1.fill(self,"nodes",{},smalltalk.ClassSorterNode)})}, args: [], source: "nodes\x0a\x09^nodes", messageSends: [], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.ClassSorterNode)})}, args: [], source: "theClass\x0a\x09^theClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.ClassSorterNode)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "traverseClassesWith:", category: 'visiting', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aCollection)._add_(self._theClass()); _st(_st(self._nodes())._sorted_((function(a,b){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(a)._theClass())._name()).__lt_eq(_st(_st(b)._theClass())._name()); }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1)})})))._do_((function(aNode){ return smalltalk.withContext(function($ctx2) { return _st(aNode)._traverseClassesWith_(aCollection); }, function($ctx2) {$ctx2.fillBlock({aNode:aNode},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"traverseClassesWith:",{aCollection:aCollection},smalltalk.ClassSorterNode)})}, args: ["aCollection"], source: "traverseClassesWith: aCollection\x0a\x09\x22sort classes alphabetically Issue #143\x22\x0a\x0a\x09aCollection add: self theClass.\x0a\x09(self nodes sorted: [:a :b | a theClass name <= b theClass name ]) do: [:aNode |\x0a\x09\x09aNode traverseClassesWith: aCollection ].", messageSends: ["add:", "theClass", "do:", "traverseClassesWith:", "sorted:", "<=", "name", "nodes"], referencedClasses: [] }), smalltalk.ClassSorterNode); smalltalk.addMethod( smalltalk.method({ selector: "on:classes:level:", category: 'instance creation', fn: function (aClass,aCollection,anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._theClass_(aClass); _st($2)._level_(anInteger); _st($2)._getNodesFrom_(aCollection); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:classes:level:",{aClass:aClass,aCollection:aCollection,anInteger:anInteger},smalltalk.ClassSorterNode.klass)})}, args: ["aClass", "aCollection", "anInteger"], source: "on: aClass classes: aCollection level: anInteger\x0a\x09^self new\x0a\x09\x09theClass: aClass;\x0a\x09\x09level: anInteger;\x0a\x09\x09getNodesFrom: aCollection;\x0a\x09\x09yourself", messageSends: ["theClass:", "new", "level:", "getNodesFrom:", "yourself"], referencedClasses: [] }), smalltalk.ClassSorterNode.klass); }); define("amber_core/Kernel-Methods", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Methods'); smalltalk.packages["Kernel-Methods"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('BlockClosure', smalltalk.Object, [], 'Kernel-Methods'); smalltalk.BlockClosure.comment="I represent a lexical closure.\x0aI am is directly mapped to JavaScript Function.\x0a\x0a## API\x0a\x0a1. Evaluation\x0a\x0a My instances get evaluated with the `#value*` methods in the 'evaluating' protocol.\x0a\x0a Example: ` [ :x | x + 1 ] value: 3 \x22Answers 4\x22 `\x0a\x0a2. Control structures\x0a\x0a Blocks are used (together with `Boolean`) for control structures (methods in the `controlling` protocol).\x0a\x0a Example: `aBlock whileTrue: [ ... ]`\x0a\x0a3. Error handling\x0a\x0a I provide the `#on:do:` method for handling exceptions.\x0a\x0a Example: ` aBlock on: MessageNotUnderstood do: [ :ex | ... ] `"; smalltalk.addMethod( smalltalk.method({ selector: "applyTo:arguments:", category: 'evaluating', fn: function (anObject,aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { return self.apply(anObject, aCollection); return self}, function($ctx1) {$ctx1.fill(self,"applyTo:arguments:",{anObject:anObject,aCollection:aCollection},smalltalk.BlockClosure)})}, args: ["anObject", "aCollection"], source: "applyTo: anObject arguments: aCollection\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "asCompiledMethod:", category: 'converting', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.method({selector:aString, fn:self});; return self}, function($ctx1) {$ctx1.fill(self,"asCompiledMethod:",{aString:aString},smalltalk.BlockClosure)})}, args: ["aString"], source: "asCompiledMethod: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "compiledSource", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toString(); return self}, function($ctx1) {$ctx1.fill(self,"compiledSource",{},smalltalk.BlockClosure)})}, args: [], source: "compiledSource\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "currySelf", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return function () { var args = [ this ]; args.push.apply(args, arguments); return self.apply(null, args); } ; return self}, function($ctx1) {$ctx1.fill(self,"currySelf",{},smalltalk.BlockClosure)})}, args: [], source: "currySelf\x0a\x09\x22Transforms [ :selfarg :x :y | stcode ] block\x0a\x09which represents JS function (selfarg, x, y, ...) {jscode}\x0a\x09into function (x, y, ...) {jscode} that takes selfarg from 'this'.\x0a\x09IOW, it is usable as JS method and first arg takes the receiver.\x22\x0a\x09\x0a\x09<\x0a\x09\x09return function () {\x0a\x09\x09\x09var args = [ this ];\x0a\x09\x09\x09args.push.apply(args, arguments);\x0a\x09\x09\x09return self.apply(null, args);\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "ensure:", category: 'evaluating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { try{return self._value()}finally{aBlock._value()}; return self}, function($ctx1) {$ctx1.fill(self,"ensure:",{aBlock:aBlock},smalltalk.BlockClosure)})}, args: ["aBlock"], source: "ensure: aBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "fork", category: 'timeout/interval', fn: function (){ var self=this; function $ForkPool(){return smalltalk.ForkPool||(typeof ForkPool=="undefined"?nil:ForkPool)} return smalltalk.withContext(function($ctx1) { _st(_st($ForkPool())._default())._fork_(self); return self}, function($ctx1) {$ctx1.fill(self,"fork",{},smalltalk.BlockClosure)})}, args: [], source: "fork\x0a\x09ForkPool default fork: self", messageSends: ["fork:", "default"], referencedClasses: ["ForkPool"] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "new", category: 'evaluating', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return new self(); return self}, function($ctx1) {$ctx1.fill(self,"new",{},smalltalk.BlockClosure)})}, args: [], source: "new\x0a\x09\x22Use the receiver as a JS constructor.\x0a\x09*Do not* use this method to instanciate Smalltalk objects!\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "newValue:", category: 'evaluating', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._newWithValues_([anObject]); return $1; }, function($ctx1) {$ctx1.fill(self,"newValue:",{anObject:anObject},smalltalk.BlockClosure)})}, args: ["anObject"], source: "newValue: anObject\x0a^ self newWithValues: { anObject }", messageSends: ["newWithValues:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "newValue:value:", category: 'evaluating', fn: function (anObject,anObject2){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._newWithValues_([anObject,anObject2]); return $1; }, function($ctx1) {$ctx1.fill(self,"newValue:value:",{anObject:anObject,anObject2:anObject2},smalltalk.BlockClosure)})}, args: ["anObject", "anObject2"], source: "newValue: anObject value: anObject2\x0a^ self newWithValues: { anObject. anObject2 }.", messageSends: ["newWithValues:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "newValue:value:value:", category: 'evaluating', fn: function (anObject,anObject2,anObject3){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._newWithValues_([anObject,anObject2,anObject3]); return $1; }, function($ctx1) {$ctx1.fill(self,"newValue:value:value:",{anObject:anObject,anObject2:anObject2,anObject3:anObject3},smalltalk.BlockClosure)})}, args: ["anObject", "anObject2", "anObject3"], source: "newValue: anObject value: anObject2 value: anObject3\x0a^ self newWithValues: { anObject. anObject2. anObject3 }.", messageSends: ["newWithValues:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "newWithValues:", category: 'evaluating', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var constructor = function() {}; constructor.prototype = self.prototype; var object = new constructor; var result = self.apply(object, aCollection); return typeof result === "object" ? result : object;; return self}, function($ctx1) {$ctx1.fill(self,"newWithValues:",{aCollection:aCollection},smalltalk.BlockClosure)})}, args: ["aCollection"], source: "newWithValues: aCollection\x0a\x22Use the receiver as a JavaScript constructor with a variable number of arguments.\x0aAnswer the object created using the operator `new`.\x0a\x0aThis algorithm was inspired by http://stackoverflow.com/a/6069331.\x0a\x0aHere's a general breakdown of what's going on:\x0a1) Create a new, empty constructor function.\x0a2) Set it's prototype to the receiver's prototype. Because the receiver is a `BlockClosure`, it is also a JavaScript function.\x0a3) Instantiate a new object using the constructor function just created. \x0a This forces the interpreter to set the internal [[prototype]] property to what was set on the function before. \x0a This has to be done, as we have no access to the [[prototype]] property externally.\x0a4) Apply `self` to the object I just instantiated.\x22\x0a\x0a<\x0a\x09var constructor = function() {};\x0a\x09constructor.prototype = self.prototype;\x0a\x09var object = new constructor;\x0a\x09var result = self.apply(object, aCollection);\x0a\x09return typeof result === \x22object\x22 ? result : object;\x0a>", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "numArgs", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.length; return self}, function($ctx1) {$ctx1.fill(self,"numArgs",{},smalltalk.BlockClosure)})}, args: [], source: "numArgs\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "on:do:", category: 'error handling', fn: function (anErrorClass,aBlock){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$1; $1=self._try_catch_(self,(function(error){ var smalltalkError; return smalltalk.withContext(function($ctx2) { smalltalkError=_st(_st($Smalltalk())._current())._asSmalltalkException_(error); smalltalkError; $2=_st(smalltalkError)._isKindOf_(anErrorClass); if(smalltalk.assert($2)){ return _st(aBlock)._value_(smalltalkError); } else { return _st(smalltalkError)._resignal(); }; }, function($ctx2) {$ctx2.fillBlock({error:error,smalltalkError:smalltalkError},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"on:do:",{anErrorClass:anErrorClass,aBlock:aBlock},smalltalk.BlockClosure)})}, args: ["anErrorClass", "aBlock"], source: "on: anErrorClass do: aBlock\x0a\x09\x22All exceptions thrown in the Smalltalk stack are cought.\x0a\x09Convert all JS exceptions to JavaScriptException instances.\x22\x0a\x09\x0a\x09^self try: self catch: [ :error | | smalltalkError |\x0a\x09\x09smalltalkError := Smalltalk current asSmalltalkException: error.\x0a\x09\x09(smalltalkError isKindOf: anErrorClass)\x0a\x09\x09ifTrue: [ aBlock value: smalltalkError ]\x0a\x09\x09ifFalse: [ smalltalkError resignal ] ]", messageSends: ["try:catch:", "asSmalltalkException:", "current", "ifTrue:ifFalse:", "value:", "resignal", "isKindOf:"], referencedClasses: ["Smalltalk"] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return nil; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.BlockClosure)})}, args: [], source: "receiver\x0a\x09^ nil", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "timeToRun", category: 'evaluating', fn: function (){ var self=this; function $Date(){return smalltalk.Date||(typeof Date=="undefined"?nil:Date)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Date())._millisecondsToRun_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"timeToRun",{},smalltalk.BlockClosure)})}, args: [], source: "timeToRun\x0a\x09\x22Answer the number of milliseconds taken to execute this block.\x22\x0a\x0a\x09^ Date millisecondsToRun: self", messageSends: ["millisecondsToRun:"], referencedClasses: ["Date"] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'evaluating', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self();; return self}, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.BlockClosure)})}, args: [], source: "value\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'evaluating', fn: function (anArg){ var self=this; return smalltalk.withContext(function($ctx1) { return self(anArg);; return self}, function($ctx1) {$ctx1.fill(self,"value:",{anArg:anArg},smalltalk.BlockClosure)})}, args: ["anArg"], source: "value: anArg\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "value:value:", category: 'evaluating', fn: function (firstArg,secondArg){ var self=this; return smalltalk.withContext(function($ctx1) { return self(firstArg, secondArg);; return self}, function($ctx1) {$ctx1.fill(self,"value:value:",{firstArg:firstArg,secondArg:secondArg},smalltalk.BlockClosure)})}, args: ["firstArg", "secondArg"], source: "value: firstArg value: secondArg\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "value:value:value:", category: 'evaluating', fn: function (firstArg,secondArg,thirdArg){ var self=this; return smalltalk.withContext(function($ctx1) { return self(firstArg, secondArg, thirdArg);; return self}, function($ctx1) {$ctx1.fill(self,"value:value:value:",{firstArg:firstArg,secondArg:secondArg,thirdArg:thirdArg},smalltalk.BlockClosure)})}, args: ["firstArg", "secondArg", "thirdArg"], source: "value: firstArg value: secondArg value: thirdArg\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "valueWithInterval:", category: 'timeout/interval', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { var interval = setInterval(self, aNumber); return smalltalk.Timeout._on_(interval); ; return self}, function($ctx1) {$ctx1.fill(self,"valueWithInterval:",{aNumber:aNumber},smalltalk.BlockClosure)})}, args: ["aNumber"], source: "valueWithInterval: aNumber\x0a\x09<\x0a\x09\x09var interval = setInterval(self, aNumber);\x0a\x09\x09return smalltalk.Timeout._on_(interval);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "valueWithPossibleArguments:", category: 'evaluating', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { return self.apply(null, aCollection);; return self}, function($ctx1) {$ctx1.fill(self,"valueWithPossibleArguments:",{aCollection:aCollection},smalltalk.BlockClosure)})}, args: ["aCollection"], source: "valueWithPossibleArguments: aCollection\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "valueWithTimeout:", category: 'timeout/interval', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { var timeout = setTimeout(self, aNumber); return smalltalk.Timeout._on_(timeout); ; return self}, function($ctx1) {$ctx1.fill(self,"valueWithTimeout:",{aNumber:aNumber},smalltalk.BlockClosure)})}, args: ["aNumber"], source: "valueWithTimeout: aNumber\x0a\x09<\x0a\x09\x09var timeout = setTimeout(self, aNumber);\x0a\x09\x09return smalltalk.Timeout._on_(timeout);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "whileFalse", category: 'controlling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"whileFalse",{},smalltalk.BlockClosure)})}, args: [], source: "whileFalse\x0a\x09self whileFalse: []", messageSends: ["whileFalse:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "whileFalse:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { while(!smalltalk.assert(self._value())) {aBlock._value()}; return self}, function($ctx1) {$ctx1.fill(self,"whileFalse:",{aBlock:aBlock},smalltalk.BlockClosure)})}, args: ["aBlock"], source: "whileFalse: aBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "whileTrue", category: 'controlling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"whileTrue",{},smalltalk.BlockClosure)})}, args: [], source: "whileTrue\x0a\x09self whileTrue: []", messageSends: ["whileTrue:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "whileTrue:", category: 'controlling', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { while(smalltalk.assert(self._value())) {aBlock._value()}; return self}, function($ctx1) {$ctx1.fill(self,"whileTrue:",{aBlock:aBlock},smalltalk.BlockClosure)})}, args: ["aBlock"], source: "whileTrue: aBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addClass('CompiledMethod', smalltalk.Object, [], 'Kernel-Methods'); smalltalk.CompiledMethod.comment="I represent a class method of the system. I hold the source and compiled code of a class method.\x0a\x0a## API\x0aMy instances can be accessed using `Behavior >> #methodAt:`\x0a\x0a Object methodAt: 'asString'\x0a\x0aSource code access:\x0a\x0a\x09(String methodAt: 'lines') source\x0a\x0aReferenced classes:\x0a\x0a\x09(String methodAt: 'lines') referencedClasses\x0a\x0aMessages sent from an instance:\x0a\x09\x0a\x09(String methodAt: 'lines') messageSends"; smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.args || []; return self}, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.CompiledMethod)})}, args: [], source: "arguments\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "category", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._basicAt_("category"); if(($receiver = $2) == nil || $receiver == undefined){ $1=self._defaultCategory(); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"category",{},smalltalk.CompiledMethod)})}, args: [], source: "category\x0a\x09^(self basicAt: 'category') ifNil: [ self defaultCategory ]", messageSends: ["ifNil:", "defaultCategory", "basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "category:", category: 'accessing', fn: function (aString){ var self=this; var oldProtocol; function $MethodMoved(){return smalltalk.MethodMoved||(typeof MethodMoved=="undefined"?nil:MethodMoved)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; oldProtocol=self._protocol(); self._basicAt_put_("category",aString); $1=_st($MethodMoved())._new(); _st($1)._method_(self); _st($1)._oldProtocol_(oldProtocol); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); $3=self._methodClass(); if(($receiver = $3) == nil || $receiver == undefined){ $3; } else { _st(_st(self._methodClass())._organization())._addElement_(aString); _st(_st(_st(self._methodClass())._methods())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocol()).__eq(oldProtocol); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._ifEmpty_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(self._methodClass())._organization())._removeElement_(oldProtocol); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); }; return self}, function($ctx1) {$ctx1.fill(self,"category:",{aString:aString,oldProtocol:oldProtocol},smalltalk.CompiledMethod)})}, args: ["aString"], source: "category: aString\x0a\x09| oldProtocol |\x0a\x09oldProtocol := self protocol.\x0a\x09self basicAt: 'category' put: aString.\x0a\x0a\x09SystemAnnouncer current announce: (MethodMoved new\x0a\x09\x09method: self;\x0a\x09\x09oldProtocol: oldProtocol;\x0a\x09\x09yourself).\x0a\x0a\x09self methodClass ifNotNil: [\x0a\x09\x09self methodClass organization addElement: aString.\x0a\x09\x0a\x09\x09(self methodClass methods\x0a\x09\x09\x09select: [ :each | each protocol = oldProtocol ])\x0a\x09\x09\x09ifEmpty: [ self methodClass organization removeElement: oldProtocol ] ]", messageSends: ["protocol", "basicAt:put:", "announce:", "method:", "new", "oldProtocol:", "yourself", "current", "ifNotNil:", "addElement:", "organization", "methodClass", "ifEmpty:", "removeElement:", "select:", "=", "methods"], referencedClasses: ["MethodMoved", "SystemAnnouncer"] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "defaultCategory", category: 'defaults', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "as yet unclassified"; }, function($ctx1) {$ctx1.fill(self,"defaultCategory",{},smalltalk.CompiledMethod)})}, args: [], source: "defaultCategory\x0a\x09^ 'as yet unclassified'", messageSends: [], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "fn", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("fn"); return $1; }, function($ctx1) {$ctx1.fill(self,"fn",{},smalltalk.CompiledMethod)})}, args: [], source: "fn\x0a\x09^self basicAt: 'fn'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "fn:", category: 'accessing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._basicAt_put_("fn",aBlock); return self}, function($ctx1) {$ctx1.fill(self,"fn:",{aBlock:aBlock},smalltalk.CompiledMethod)})}, args: ["aBlock"], source: "fn: aBlock\x0a\x09self basicAt: 'fn' put: aBlock", messageSends: ["basicAt:put:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "isCompiledMethod", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isCompiledMethod",{},smalltalk.CompiledMethod)})}, args: [], source: "isCompiledMethod\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "isOverridden", category: 'testing', fn: function (){ var self=this; var selector; return smalltalk.withContext(function($ctx1) { var $1; var $early={}; try { selector=self._selector(); _st(self._methodClass())._allSubclassesDo_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st(each)._includesSelector_(selector); if(smalltalk.assert($1)){ throw $early=[true]; }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return false; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"isOverridden",{selector:selector},smalltalk.CompiledMethod)})}, args: [], source: "isOverridden\x0a\x09| selector |\x0a \x0a selector := self selector.\x0a self methodClass allSubclassesDo: [ :each |\x0a\x09 (each includesSelector: selector)\x0a \x09ifTrue: [ ^ true ] ].\x0a\x09^ false", messageSends: ["selector", "allSubclassesDo:", "ifTrue:", "includesSelector:", "methodClass"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "isOverride", category: 'testing', fn: function (){ var self=this; var superclass; return smalltalk.withContext(function($ctx1) { var $1,$2; superclass=_st(self._methodClass())._superclass(); $1=superclass; if(($receiver = $1) == nil || $receiver == undefined){ return false; } else { $1; }; $2=_st(_st(_st(self._methodClass())._superclass())._lookupSelector_(self._selector()))._notNil(); return $2; }, function($ctx1) {$ctx1.fill(self,"isOverride",{superclass:superclass},smalltalk.CompiledMethod)})}, args: [], source: "isOverride\x0a\x09| superclass |\x0a \x0a superclass := self methodClass superclass.\x0a\x09superclass ifNil: [ ^ false ].\x0a\x09\x0a ^ (self methodClass superclass lookupSelector: self selector) notNil", messageSends: ["superclass", "methodClass", "ifNil:", "notNil", "lookupSelector:", "selector"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "messageSends", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("messageSends"); return $1; }, function($ctx1) {$ctx1.fill(self,"messageSends",{},smalltalk.CompiledMethod)})}, args: [], source: "messageSends\x0a\x09^self basicAt: 'messageSends'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "methodClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("methodClass"); return $1; }, function($ctx1) {$ctx1.fill(self,"methodClass",{},smalltalk.CompiledMethod)})}, args: [], source: "methodClass\x0a\x09^self basicAt: 'methodClass'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "protocol", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._category(); return $1; }, function($ctx1) {$ctx1.fill(self,"protocol",{},smalltalk.CompiledMethod)})}, args: [], source: "protocol\x0a\x09^ self category", messageSends: ["category"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "protocol:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._category_(aString); return self}, function($ctx1) {$ctx1.fill(self,"protocol:",{aString:aString},smalltalk.CompiledMethod)})}, args: ["aString"], source: "protocol: aString\x0a\x09self category: aString", messageSends: ["category:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "referencedClasses", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("referencedClasses"); return $1; }, function($ctx1) {$ctx1.fill(self,"referencedClasses",{},smalltalk.CompiledMethod)})}, args: [], source: "referencedClasses\x0a\x09^self basicAt: 'referencedClasses'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("selector"); return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.CompiledMethod)})}, args: [], source: "selector\x0a\x09^self basicAt: 'selector'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._basicAt_put_("selector",aString); return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.CompiledMethod)})}, args: ["aString"], source: "selector: aString\x0a\x09self basicAt: 'selector' put: aString", messageSends: ["basicAt:put:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._basicAt_("source"); if(($receiver = $2) == nil || $receiver == undefined){ $1=""; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.CompiledMethod)})}, args: [], source: "source\x0a\x09^(self basicAt: 'source') ifNil: ['']", messageSends: ["ifNil:", "basicAt:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._basicAt_put_("source",aString); return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.CompiledMethod)})}, args: ["aString"], source: "source: aString\x0a\x09self basicAt: 'source' put: aString", messageSends: ["basicAt:put:"], referencedClasses: [] }), smalltalk.CompiledMethod); smalltalk.addClass('ForkPool', smalltalk.Object, ['poolSize', 'maxPoolSize', 'queue', 'worker'], 'Kernel-Methods'); smalltalk.ForkPool.comment="I am responsible for handling forked blocks.\x0aThe pool size sets the maximum concurrent forked blocks.\x0a\x0a## API\x0a\x0aThe default instance is accessed with `#default`.\x0aThe maximum concurrent forked blocks can be set with `#maxPoolSize:`.\x0a\x0aForking is done via `BlockClosure >> #fork`"; smalltalk.addMethod( smalltalk.method({ selector: "addWorker", category: 'private', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@worker"])._valueWithTimeout_((0)); self["@poolSize"]=_st(self["@poolSize"]).__plus((1)); return self}, function($ctx1) {$ctx1.fill(self,"addWorker",{},smalltalk.ForkPool)})}, args: [], source: "addWorker\x0a\x09worker valueWithTimeout: 0.\x0a\x09poolSize := poolSize + 1", messageSends: ["valueWithTimeout:", "+"], referencedClasses: [] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "defaultMaxPoolSize", category: 'defaults', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._class())._defaultMaxPoolSize(); return $1; }, function($ctx1) {$ctx1.fill(self,"defaultMaxPoolSize",{},smalltalk.ForkPool)})}, args: [], source: "defaultMaxPoolSize\x0a\x09^ self class defaultMaxPoolSize", messageSends: ["defaultMaxPoolSize", "class"], referencedClasses: [] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "fork:", category: 'actions', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@poolSize"]).__lt(self._maxPoolSize()); if(smalltalk.assert($1)){ self._addWorker(); }; _st(self["@queue"])._nextPut_(aBlock); return self}, function($ctx1) {$ctx1.fill(self,"fork:",{aBlock:aBlock},smalltalk.ForkPool)})}, args: ["aBlock"], source: "fork: aBlock\x0a\x09poolSize < self maxPoolSize ifTrue: [ self addWorker ].\x0a\x09queue nextPut: aBlock", messageSends: ["ifTrue:", "addWorker", "<", "maxPoolSize", "nextPut:"], referencedClasses: [] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $Queue(){return smalltalk.Queue||(typeof Queue=="undefined"?nil:Queue)} return smalltalk.withContext(function($ctx1) { smalltalk.ForkPool.superclass.fn.prototype._initialize.apply(_st(self), []); self["@poolSize"]=(0); self["@queue"]=_st($Queue())._new(); self["@worker"]=self._makeWorker(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ForkPool)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09\x0a\x09poolSize := 0.\x0a\x09queue := Queue new.\x0a\x09worker := self makeWorker", messageSends: ["initialize", "new", "makeWorker"], referencedClasses: ["Queue"] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "makeWorker", category: 'initialization', fn: function (){ var self=this; var sentinel; function $Object(){return smalltalk.Object||(typeof Object=="undefined"?nil:Object)} return smalltalk.withContext(function($ctx1) { var $2,$1; sentinel=_st($Object())._new(); $1=(function(){ var block; return smalltalk.withContext(function($ctx2) { self["@poolSize"]=_st(self["@poolSize"]).__minus((1)); self["@poolSize"]; block=_st(self["@queue"])._nextIfAbsent_((function(){ return smalltalk.withContext(function($ctx3) { return sentinel; }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); block; $2=_st(block).__eq_eq(sentinel); if(! smalltalk.assert($2)){ return _st((function(){ return smalltalk.withContext(function($ctx3) { return _st(block)._value(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})}))._ensure_((function(){ return smalltalk.withContext(function($ctx3) { return self._addWorker(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }; }, function($ctx2) {$ctx2.fillBlock({block:block},$ctx1)})}); return $1; }, function($ctx1) {$ctx1.fill(self,"makeWorker",{sentinel:sentinel},smalltalk.ForkPool)})}, args: [], source: "makeWorker\x0a\x09| sentinel |\x0a\x09sentinel := Object new.\x0a\x09^[ | block |\x0a\x09\x09poolSize := poolSize - 1.\x0a\x09\x09block := queue nextIfAbsent: [ sentinel ].\x0a\x09\x09block == sentinel ifFalse: [\x0a\x09\x09\x09[ block value ] ensure: [ self addWorker ]]]", messageSends: ["new", "-", "nextIfAbsent:", "ifFalse:", "ensure:", "addWorker", "value", "=="], referencedClasses: ["Object"] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "maxPoolSize", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@maxPoolSize"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=self._defaultMaxPoolSize(); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"maxPoolSize",{},smalltalk.ForkPool)})}, args: [], source: "maxPoolSize\x0a\x09^ maxPoolSize ifNil: [ self defaultMaxPoolSize ]", messageSends: ["ifNil:", "defaultMaxPoolSize"], referencedClasses: [] }), smalltalk.ForkPool); smalltalk.addMethod( smalltalk.method({ selector: "maxPoolSize:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@maxPoolSize"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"maxPoolSize:",{anInteger:anInteger},smalltalk.ForkPool)})}, args: ["anInteger"], source: "maxPoolSize: anInteger\x0a\x09maxPoolSize := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.ForkPool); smalltalk.ForkPool.klass.iVarNames = ['default']; smalltalk.addMethod( smalltalk.method({ selector: "default", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@default"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@default"]=self._new(); $1=self["@default"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"default",{},smalltalk.ForkPool.klass)})}, args: [], source: "default\x0a\x09^default ifNil: [ default := self new ]", messageSends: ["ifNil:", "new"], referencedClasses: [] }), smalltalk.ForkPool.klass); smalltalk.addMethod( smalltalk.method({ selector: "defaultMaxPoolSize", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return (100); }, function($ctx1) {$ctx1.fill(self,"defaultMaxPoolSize",{},smalltalk.ForkPool.klass)})}, args: [], source: "defaultMaxPoolSize\x0a\x09^100", messageSends: [], referencedClasses: [] }), smalltalk.ForkPool.klass); smalltalk.addMethod( smalltalk.method({ selector: "resetDefault", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self["@default"]=nil; return self}, function($ctx1) {$ctx1.fill(self,"resetDefault",{},smalltalk.ForkPool.klass)})}, args: [], source: "resetDefault\x0a\x09default := nil", messageSends: [], referencedClasses: [] }), smalltalk.ForkPool.klass); smalltalk.addClass('Message', smalltalk.Object, ['selector', 'arguments'], 'Kernel-Methods'); smalltalk.Message.comment="In general, the system does not use instances of me for efficiency reasons.\x0aHowever, when a message is not understood by its receiver, the interpreter will make up an instance of it in order to capture the information involved in an actual message transmission.\x0aThis instance is sent it as an argument with the message `#doesNotUnderstand:` to the receiver.\x0a\x0aSee boot.js, `messageNotUnderstood` and its counterpart `Object >> #doesNotUnderstand:`\x0a\x0a## API\x0a\x0aBesides accessing methods, `#sendTo:` provides a convenient way to send a message to an object."; smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@arguments"]; return $1; }, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.Message)})}, args: [], source: "arguments\x0a\x09^arguments", messageSends: [], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "arguments:", category: 'accessing', fn: function (anArray){ var self=this; return smalltalk.withContext(function($ctx1) { self["@arguments"]=anArray; return self}, function($ctx1) {$ctx1.fill(self,"arguments:",{anArray:anArray},smalltalk.Message)})}, args: ["anArray"], source: "arguments: anArray\x0a\x09arguments := anArray", messageSends: [], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.Message.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); $1=aStream; _st($1)._nextPutAll_("("); _st($1)._nextPutAll_(self._selector()); $2=_st($1)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Message)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream\x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self selector;\x0a\x09\x09nextPutAll: ')'", messageSends: ["printOn:", "nextPutAll:", "selector"], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@selector"]; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.Message)})}, args: [], source: "selector\x0a\x09^selector", messageSends: [], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@selector"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.Message)})}, args: ["aString"], source: "selector: aString\x0a\x09selector := aString", messageSends: [], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "sendTo:", category: 'actions', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anObject)._perform_withArguments_(self._selector(),self._arguments()); return $1; }, function($ctx1) {$ctx1.fill(self,"sendTo:",{anObject:anObject},smalltalk.Message)})}, args: ["anObject"], source: "sendTo: anObject\x0a\x09^ anObject perform: self selector withArguments: self arguments", messageSends: ["perform:withArguments:", "selector", "arguments"], referencedClasses: [] }), smalltalk.Message); smalltalk.addMethod( smalltalk.method({ selector: "selector:arguments:", category: 'instance creation', fn: function (aString,anArray){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._selector_(aString); _st($2)._arguments_(anArray); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"selector:arguments:",{aString:aString,anArray:anArray},smalltalk.Message.klass)})}, args: ["aString", "anArray"], source: "selector: aString arguments: anArray\x0a\x09^self new\x0a\x09\x09selector: aString;\x0a\x09\x09arguments: anArray;\x0a\x09\x09yourself", messageSends: ["selector:", "new", "arguments:", "yourself"], referencedClasses: [] }), smalltalk.Message.klass); smalltalk.addClass('MessageSend', smalltalk.Object, ['receiver', 'message'], 'Kernel-Methods'); smalltalk.MessageSend.comment="I encapsulate message sends to objects. Arguments can be either predefined or supplied when the message send is performed. \x0a\x0a## API\x0a\x0aUse `#value` to perform a message send with its predefined arguments and `#value:*` if additonal arguments have to supplied."; smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@message"])._arguments(); return $1; }, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.MessageSend)})}, args: [], source: "arguments\x0a\x09^ message arguments", messageSends: ["arguments"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "arguments:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@message"])._arguments_(aCollection); return self}, function($ctx1) {$ctx1.fill(self,"arguments:",{aCollection:aCollection},smalltalk.MessageSend)})}, args: ["aCollection"], source: "arguments: aCollection\x0a\x09message arguments: aCollection", messageSends: ["arguments:"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $Message(){return smalltalk.Message||(typeof Message=="undefined"?nil:Message)} return smalltalk.withContext(function($ctx1) { smalltalk.MessageSend.superclass.fn.prototype._initialize.apply(_st(self), []); self["@message"]=_st($Message())._new(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.MessageSend)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09message := Message new", messageSends: ["initialize", "new"], referencedClasses: ["Message"] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.MessageSend.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); $1=aStream; _st($1)._nextPutAll_("("); _st($1)._nextPutAll_(self._receiver()); _st($1)._nextPutAll_(" >> "); _st($1)._nextPutAll_(self._selector()); $2=_st($1)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.MessageSend)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream\x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self receiver;\x0a\x09\x09nextPutAll: ' >> ';\x0a\x09\x09nextPutAll: self selector;\x0a\x09\x09nextPutAll: ')'", messageSends: ["printOn:", "nextPutAll:", "receiver", "selector"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@receiver"]; return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.MessageSend)})}, args: [], source: "receiver\x0a\x09^ receiver", messageSends: [], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "receiver:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@receiver"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"receiver:",{anObject:anObject},smalltalk.MessageSend)})}, args: ["anObject"], source: "receiver: anObject\x0a\x09receiver := anObject", messageSends: [], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@message"])._selector(); return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.MessageSend)})}, args: [], source: "selector\x0a\x09^ message selector", messageSends: ["selector"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@message"])._selector_(aString); return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.MessageSend)})}, args: ["aString"], source: "selector: aString\x0a\x09message selector: aString", messageSends: ["selector:"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'evaluating', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@message"])._sendTo_(self._receiver()); return $1; }, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.MessageSend)})}, args: [], source: "value\x0a\x09^ message sendTo: self receiver", messageSends: ["sendTo:", "receiver"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'evaluating', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self["@message"]; _st($2)._arguments_([anObject]); $3=_st($2)._sendTo_(self._receiver()); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},smalltalk.MessageSend)})}, args: ["anObject"], source: "value: anObject\x0a\x09^ message \x0a\x09\x09arguments: { anObject };\x0a\x09\x09sendTo: self receiver", messageSends: ["arguments:", "sendTo:", "receiver"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "value:value:", category: 'evaluating', fn: function (firstArgument,secondArgument){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self["@message"]; _st($2)._arguments_([firstArgument,secondArgument]); $3=_st($2)._sendTo_(self._receiver()); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"value:value:",{firstArgument:firstArgument,secondArgument:secondArgument},smalltalk.MessageSend)})}, args: ["firstArgument", "secondArgument"], source: "value: firstArgument value: secondArgument\x0a\x09^ message \x0a\x09\x09arguments: { firstArgument. secondArgument };\x0a\x09\x09sendTo: self receiver", messageSends: ["arguments:", "sendTo:", "receiver"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "value:value:value:", category: 'evaluating', fn: function (firstArgument,secondArgument,thirdArgument){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self["@message"]; _st($2)._arguments_([firstArgument,secondArgument,thirdArgument]); $3=_st($2)._sendTo_(self._receiver()); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"value:value:value:",{firstArgument:firstArgument,secondArgument:secondArgument,thirdArgument:thirdArgument},smalltalk.MessageSend)})}, args: ["firstArgument", "secondArgument", "thirdArgument"], source: "value: firstArgument value: secondArgument value: thirdArgument\x0a\x09^ message \x0a\x09\x09arguments: { firstArgument. secondArgument. thirdArgument };\x0a\x09\x09sendTo: self receiver", messageSends: ["arguments:", "sendTo:", "receiver"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addMethod( smalltalk.method({ selector: "valueWithPossibleArguments:", category: 'evaluating', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._arguments_(aCollection); $1=self._value(); return $1; }, function($ctx1) {$ctx1.fill(self,"valueWithPossibleArguments:",{aCollection:aCollection},smalltalk.MessageSend)})}, args: ["aCollection"], source: "valueWithPossibleArguments: aCollection\x0a\x09self arguments: aCollection.\x0a\x09^ self value", messageSends: ["arguments:", "value"], referencedClasses: [] }), smalltalk.MessageSend); smalltalk.addClass('MethodContext', smalltalk.Object, [], 'Kernel-Methods'); smalltalk.MethodContext.comment="I hold all the dynamic state associated with the execution of either a method activation resulting from a message send. I am used to build the call stack while debugging.\x0a\x0aMy instances are JavaScript `SmalltalkMethodContext` objects defined in `boot.js`."; smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._isBlockContext(); if(smalltalk.assert($2)){ $1=_st("a block (in ".__comma(_st(self._methodContext())._asString())).__comma(")"); } else { $1=_st(_st(_st(_st(self._receiver())._class())._name()).__comma(" >> ")).__comma(self._selector()); }; return $1; }, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.MethodContext)})}, args: [], source: "asString\x0a\x09^self isBlockContext\x0a\x09\x09ifTrue: [ 'a block (in ', self methodContext asString, ')' ]\x0a\x09\x09ifFalse: [ self receiver class name, ' >> ', self selector ]", messageSends: ["ifTrue:ifFalse:", ",", "asString", "methodContext", "selector", "name", "class", "receiver", "isBlockContext"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "home", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.homeContext; return self}, function($ctx1) {$ctx1.fill(self,"home",{},smalltalk.MethodContext)})}, args: [], source: "home\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "isBlockContext", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._selector())._isNil(); return $1; }, function($ctx1) {$ctx1.fill(self,"isBlockContext",{},smalltalk.MethodContext)})}, args: [], source: "isBlockContext\x0a\x09\x22Block context do not have selectors.\x22\x0a\x09\x0a\x09^ self selector isNil", messageSends: ["isNil", "selector"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "locals", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.locals || {}; return self}, function($ctx1) {$ctx1.fill(self,"locals",{},smalltalk.MethodContext)})}, args: [], source: "locals\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._methodContext(); if(($receiver = $2) == nil || $receiver == undefined){ $1=$2; } else { $1=_st(_st(_st(self._methodContext())._receiver())._class())._lookupSelector_(_st(self._methodContext())._selector()); }; return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.MethodContext)})}, args: [], source: "method\x0a\x09^ self methodContext ifNotNil: [\x0a\x09\x09self methodContext receiver class lookupSelector: self methodContext selector ]", messageSends: ["ifNotNil:", "lookupSelector:", "selector", "methodContext", "class", "receiver"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "methodContext", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$4,$3; $1=self._isBlockContext(); if(! smalltalk.assert($1)){ $2=self; return $2; }; $4=self._home(); if(($receiver = $4) == nil || $receiver == undefined){ $3=$4; } else { var home; home=$receiver; $3=_st(home)._methodContext(); }; return $3; }, function($ctx1) {$ctx1.fill(self,"methodContext",{},smalltalk.MethodContext)})}, args: [], source: "methodContext\x0a\x09self isBlockContext ifFalse: [ ^ self ].\x0a\x09\x0a\x09^ self home ifNotNil: [ :home |\x0a\x09\x09home methodContext ]", messageSends: ["ifFalse:", "isBlockContext", "ifNotNil:", "methodContext", "home"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "outerContext", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.outerContext || self.homeContext; return self}, function($ctx1) {$ctx1.fill(self,"outerContext",{},smalltalk.MethodContext)})}, args: [], source: "outerContext\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "pc", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.pc; return self}, function($ctx1) {$ctx1.fill(self,"pc",{},smalltalk.MethodContext)})}, args: [], source: "pc\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.MethodContext.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); $1=aStream; _st($1)._nextPutAll_("("); _st($1)._nextPutAll_(self._asString()); $2=_st($1)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.MethodContext)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream \x0a\x09\x09nextPutAll: '(';\x0a\x09\x09nextPutAll: self asString;\x0a\x09\x09nextPutAll: ')'", messageSends: ["printOn:", "nextPutAll:", "asString"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.receiver; return self}, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.MethodContext)})}, args: [], source: "receiver\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { if(self.selector) { return smalltalk.convertSelector(self.selector); } else { return nil; } ; return self}, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.MethodContext)})}, args: [], source: "selector\x0a\x09<\x0a\x09\x09if(self.selector) {\x0a\x09\x09\x09return smalltalk.convertSelector(self.selector);\x0a\x09\x09} else {\x0a\x09\x09\x09return nil;\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addMethod( smalltalk.method({ selector: "temps", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._deprecatedAPI(); $1=self._locals(); return $1; }, function($ctx1) {$ctx1.fill(self,"temps",{},smalltalk.MethodContext)})}, args: [], source: "temps\x0a\x09self deprecatedAPI.\x0a\x09\x0a\x09^ self locals", messageSends: ["deprecatedAPI", "locals"], referencedClasses: [] }), smalltalk.MethodContext); smalltalk.addClass('NativeFunction', smalltalk.Object, [], 'Kernel-Methods'); smalltalk.NativeFunction.comment="I am a wrapper around native functions, such as `WebSocket`.\x0aFor 'normal' functions (whose constructor is the JavaScript `Function` object), use `BlockClosure`.\x0a\x0a## API\x0a\x0aSee the class-side `instance creation` methods for instance creation.\x0a\x0aCreated instances will most probably be instance of `JSObjectProxy`.\x0a\x0a## Usage example:\x0a\x0a\x09| ws |\x0a\x09ws := NativeFunction constructor: 'WebSocket' value: 'ws://localhost'.\x0a\x09ws at: 'onopen' put: [ ws send: 'hey there from Amber' ]"; smalltalk.addMethod( smalltalk.method({ selector: "constructor:", category: 'instance creation', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var native=eval(aString); return new native(); ; return self}, function($ctx1) {$ctx1.fill(self,"constructor:",{aString:aString},smalltalk.NativeFunction.klass)})}, args: ["aString"], source: "constructor: aString\x0a\x09<\x0a\x09\x09var native=eval(aString);\x0a\x09\x09return new native();\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.NativeFunction.klass); smalltalk.addMethod( smalltalk.method({ selector: "constructor:value:", category: 'instance creation', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var native=eval(aString); return new native(anObject); ; return self}, function($ctx1) {$ctx1.fill(self,"constructor:value:",{aString:aString,anObject:anObject},smalltalk.NativeFunction.klass)})}, args: ["aString", "anObject"], source: "constructor: aString value:anObject\x0a\x09<\x0a\x09\x09var native=eval(aString);\x0a\x09\x09return new native(anObject);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.NativeFunction.klass); smalltalk.addMethod( smalltalk.method({ selector: "constructor:value:value:", category: 'instance creation', fn: function (aString,anObject,anObject2){ var self=this; return smalltalk.withContext(function($ctx1) { var native=eval(aString); return new native(anObject,anObject2); ; return self}, function($ctx1) {$ctx1.fill(self,"constructor:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2},smalltalk.NativeFunction.klass)})}, args: ["aString", "anObject", "anObject2"], source: "constructor: aString value:anObject value: anObject2\x0a\x09<\x0a\x09\x09var native=eval(aString);\x0a\x09\x09return new native(anObject,anObject2);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.NativeFunction.klass); smalltalk.addMethod( smalltalk.method({ selector: "constructor:value:value:value:", category: 'instance creation', fn: function (aString,anObject,anObject2,anObject3){ var self=this; return smalltalk.withContext(function($ctx1) { var native=eval(aString); return new native(anObject,anObject2, anObject3); ; return self}, function($ctx1) {$ctx1.fill(self,"constructor:value:value:value:",{aString:aString,anObject:anObject,anObject2:anObject2,anObject3:anObject3},smalltalk.NativeFunction.klass)})}, args: ["aString", "anObject", "anObject2", "anObject3"], source: "constructor: aString value:anObject value: anObject2 value:anObject3\x0a\x09<\x0a\x09\x09var native=eval(aString);\x0a\x09\x09return new native(anObject,anObject2, anObject3);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.NativeFunction.klass); smalltalk.addMethod( smalltalk.method({ selector: "exists:", category: 'testing', fn: function (aString){ var self=this; function $PlatformInterface(){return smalltalk.PlatformInterface||(typeof PlatformInterface=="undefined"?nil:PlatformInterface)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($PlatformInterface())._existsGlobal_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"exists:",{aString:aString},smalltalk.NativeFunction.klass)})}, args: ["aString"], source: "exists: aString\x0a\x09^PlatformInterface existsGlobal: aString", messageSends: ["existsGlobal:"], referencedClasses: ["PlatformInterface"] }), smalltalk.NativeFunction.klass); smalltalk.addClass('Timeout', smalltalk.Object, ['rawTimeout'], 'Kernel-Methods'); smalltalk.Timeout.comment="I am wrapping the returns from `set{Timeout,Interval}`.\x0a\x0a## Motivation\x0a\x0aNumber suffices in browsers, but node.js returns an object."; smalltalk.addMethod( smalltalk.method({ selector: "clearInterval", category: 'timeout/interval', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var interval = self["@rawTimeout"]; clearInterval(interval); ; return self}, function($ctx1) {$ctx1.fill(self,"clearInterval",{},smalltalk.Timeout)})}, args: [], source: "clearInterval\x0a\x09<\x0a\x09\x09var interval = self[\x22@rawTimeout\x22];\x0a\x09\x09clearInterval(interval);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Timeout); smalltalk.addMethod( smalltalk.method({ selector: "clearTimeout", category: 'timeout/interval', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var timeout = self["@rawTimeout"]; clearTimeout(timeout); ; return self}, function($ctx1) {$ctx1.fill(self,"clearTimeout",{},smalltalk.Timeout)})}, args: [], source: "clearTimeout\x0a\x09<\x0a\x09\x09var timeout = self[\x22@rawTimeout\x22];\x0a\x09\x09clearTimeout(timeout);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Timeout); smalltalk.addMethod( smalltalk.method({ selector: "rawTimeout:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@rawTimeout"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"rawTimeout:",{anObject:anObject},smalltalk.Timeout)})}, args: ["anObject"], source: "rawTimeout: anObject\x0a\x09rawTimeout := anObject", messageSends: [], referencedClasses: [] }), smalltalk.Timeout); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._rawTimeout_(anObject); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{anObject:anObject},smalltalk.Timeout.klass)})}, args: ["anObject"], source: "on: anObject\x0a\x09^self new rawTimeout: anObject; yourself", messageSends: ["rawTimeout:", "new", "yourself"], referencedClasses: [] }), smalltalk.Timeout.klass); }); define("amber_core/Kernel-Collections", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Collections'); smalltalk.packages["Kernel-Collections"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('Association', smalltalk.Object, ['key', 'value'], 'Kernel-Collections'); smalltalk.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: "=", category: 'comparing', fn: function (anAssociation){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._class()).__eq(_st(anAssociation)._class()))._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(self._key()).__eq(_st(anAssociation)._key()))._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(self._value()).__eq(_st(anAssociation)._value()); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"=",{anAssociation:anAssociation},smalltalk.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:", "=", "value", "key", "class"], referencedClasses: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "key", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@key"]; return $1; }, function($ctx1) {$ctx1.fill(self,"key",{},smalltalk.Association)})}, args: [], source: "key\x0a\x09^key", messageSends: [], referencedClasses: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "key:", category: 'accessing', fn: function (aKey){ var self=this; return smalltalk.withContext(function($ctx1) { self["@key"]=aKey; return self}, function($ctx1) {$ctx1.fill(self,"key:",{aKey:aKey},smalltalk.Association)})}, args: ["aKey"], source: "key: aKey\x0a\x09key := aKey", messageSends: [], referencedClasses: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._key())._printOn_(aStream); _st(aStream)._nextPutAll_(" -> "); _st(self._value())._printOn_(aStream); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.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: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@value"]; return $1; }, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.Association)})}, args: [], source: "value\x0a\x09^value", messageSends: [], referencedClasses: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'accessing', fn: function (aValue){ var self=this; return smalltalk.withContext(function($ctx1) { self["@value"]=aValue; return self}, function($ctx1) {$ctx1.fill(self,"value:",{aValue:aValue},smalltalk.Association)})}, args: ["aValue"], source: "value: aValue\x0a\x09value := aValue", messageSends: [], referencedClasses: [] }), smalltalk.Association); smalltalk.addMethod( smalltalk.method({ selector: "key:value:", category: '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},smalltalk.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: [] }), smalltalk.Association.klass); smalltalk.addClass('Collection', smalltalk.Object, [], 'Kernel-Collections'); smalltalk.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: ",", category: '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},smalltalk.Collection)})}, args: ["aCollection"], source: ", aCollection\x0a\x09^self copy\x0a\x09\x09addAll: aCollection;\x0a\x09\x09yourself", messageSends: ["addAll:", "copy", "yourself"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "add:", category: '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},smalltalk.Collection)})}, args: ["anObject"], source: "add: anObject\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "addAll:", category: 'adding/removing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(aCollection)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return self._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=aCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"addAll:",{aCollection:aCollection},smalltalk.Collection)})}, args: ["aCollection"], source: "addAll: aCollection\x0a\x09aCollection do: [:each |\x0a\x09\x09self add: each].\x0a\x09^aCollection", messageSends: ["do:", "add:"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "asArray", category: 'converting', fn: function (){ var self=this; function $Array(){return smalltalk.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",{},smalltalk.Collection)})}, args: [], source: "asArray\x0a\x09^Array withAll: self", messageSends: ["withAll:"], referencedClasses: ["Array"] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.Collection)})}, args: [], source: "asJSON\x0a\x09^self asArray collect: [:each | each asJSON]", messageSends: ["collect:", "asJSON", "asArray"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "asOrderedCollection", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._asArray(); return $1; }, function($ctx1) {$ctx1.fill(self,"asOrderedCollection",{},smalltalk.Collection)})}, args: [], source: "asOrderedCollection\x0a\x09^self asArray", messageSends: ["asArray"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "asSet", category: 'converting', fn: function (){ var self=this; function $Set(){return smalltalk.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",{},smalltalk.Collection)})}, args: [], source: "asSet\x0a\x09^Set withAll: self", messageSends: ["withAll:"], referencedClasses: ["Set"] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "collect:", category: '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=_st(stream)._contents(); return $1; }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock,stream:stream},smalltalk.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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "contains:", category: 'testing', 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)})})); return false; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"contains:",{aBlock:aBlock},smalltalk.Collection)})}, args: ["aBlock"], source: "contains: 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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "copyWith:", category: '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},smalltalk.Collection)})}, args: ["anObject"], source: "copyWith: anObject\x0a\x09^self copy add: anObject; yourself", messageSends: ["add:", "copy", "yourself"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "copyWithAll:", category: '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},smalltalk.Collection)})}, args: ["aCollection"], source: "copyWithAll: aCollection\x0a\x09^self copy addAll: aCollection; yourself", messageSends: ["addAll:", "copy", "yourself"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "copyWithoutAll:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"copyWithoutAll:",{aCollection:aCollection},smalltalk.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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "detect:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"detect:",{aBlock:aBlock},smalltalk.Collection)})}, args: ["aBlock"], source: "detect: aBlock\x0a\x09^self detect: aBlock ifNone: [self errorNotFound]", messageSends: ["detect:ifNone:", "errorNotFound"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "detect:ifNone:", category: '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},smalltalk.Collection)})}, args: ["aBlock", "anotherBlock"], source: "detect: aBlock ifNone: anotherBlock\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassResponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},smalltalk.Collection)})}, args: ["aBlock"], source: "do: aBlock\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "do:separatedBy:", category: '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)})}); self._do_((function(each){ return smalltalk.withContext(function($ctx2) { _st(actionBeforeElement)._value(); return _st(aBlock)._value_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"do:separatedBy:",{aBlock:aBlock,anotherBlock:anotherBlock,actionBeforeElement:actionBeforeElement},smalltalk.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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "errorNotFound", category: '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",{},smalltalk.Collection)})}, args: [], source: "errorNotFound\x0a\x09self error: 'Object is not in the collection'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "ifEmpty:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._isEmpty(); if(smalltalk.assert($2)){ $1=_st(aBlock)._value(); } else { $1=self; }; return $1; }, function($ctx1) {$ctx1.fill(self,"ifEmpty:",{aBlock:aBlock},smalltalk.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. Note 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: self classifyMethodAs:\x0a\x09\x09(myProtocol ifEmpty: ['As yet unclassified'])\x22\x0a\x09^ self isEmpty\x0a\x09\x09ifTrue: [ aBlock value ]\x0a\x09\x09ifFalse: [ self ]", messageSends: ["ifTrue:ifFalse:", "value", "isEmpty"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "ifNotEmpty:", category: 'testing', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._notEmpty(); _st($1)._ifTrue_(aBlock); return self}, function($ctx1) {$ctx1.fill(self,"ifNotEmpty:",{aBlock:aBlock},smalltalk.Collection)})}, args: ["aBlock"], source: "ifNotEmpty: aBlock\x0a\x09self notEmpty ifTrue: aBlock.", messageSends: ["ifTrue:", "notEmpty"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "includes:", category: 'testing', fn: function (anObject){ var self=this; var sentinel; function $Object(){return smalltalk.Object||(typeof Object=="undefined"?nil:Object)} return smalltalk.withContext(function($ctx1) { var $1; sentinel=_st($Object())._new(); $1=_st(self._detect_ifNone_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each).__eq(anObject); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return sentinel; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))).__tild_eq(sentinel); return $1; }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject,sentinel:sentinel},smalltalk.Collection)})}, args: ["anObject"], source: "includes: anObject\x0a\x09| sentinel |\x0a\x09sentinel := Object new.\x0a\x09^(self detect: [ :each | each = anObject] ifNone: [ sentinel ]) ~= sentinel", messageSends: ["new", "~=", "detect:ifNone:", "="], referencedClasses: ["Object"] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "inject:into:", category: '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=result; return $1; }, function($ctx1) {$ctx1.fill(self,"inject:into:",{anObject:anObject,aBlock:aBlock,result:result},smalltalk.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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "intersection:", category: 'enumerating', fn: function (aCollection){ var self=this; var set,outputSet; function $Set(){return smalltalk.Set||(typeof Set=="undefined"?nil:Set)} return smalltalk.withContext(function($ctx1) { var $1,$2; set=self._asSet(); outputSet=_st($Set())._new(); _st(aCollection)._do_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st(_st(set)._includes_(each))._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(_st(outputSet)._includes_(each))._not(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); if(smalltalk.assert($1)){ return _st(outputSet)._add_(each); }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=_st(self._class())._withAll_(_st(outputSet)._asArray()); return $2; }, function($ctx1) {$ctx1.fill(self,"intersection:",{aCollection:aCollection,set:set,outputSet:outputSet},smalltalk.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:", "add:", "and:", "not", "includes:", "withAll:", "asArray", "class"], referencedClasses: ["Set"] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "isEmpty", category: '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",{},smalltalk.Collection)})}, args: [], source: "isEmpty\x0a\x09^self size = 0", messageSends: ["=", "size"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "notEmpty", category: '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",{},smalltalk.Collection)})}, args: [], source: "notEmpty\x0a\x09^self isEmpty not", messageSends: ["not", "isEmpty"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "occurrencesOf:", category: '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)})})); $2=tally; return $2; }, function($ctx1) {$ctx1.fill(self,"occurrencesOf:",{anObject:anObject,tally:tally},smalltalk.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: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "putOn:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"putOn:",{aStream:aStream},smalltalk.Collection)})}, args: ["aStream"], source: "putOn: aStream\x0a\x09self do: [ :each | each putOn: aStream ]", messageSends: ["do:", "putOn:"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "reject:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"reject:",{aBlock:aBlock},smalltalk.Collection)})}, args: ["aBlock"], source: "reject: aBlock\x0a\x09^ self select: [ :each | (aBlock value: each) = false ]", messageSends: ["select:", "=", "value:"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "remove:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"remove:",{anObject:anObject},smalltalk.Collection)})}, args: ["anObject"], source: "remove: anObject\x0a\x09^self remove: anObject ifAbsent: [self errorNotFound]", messageSends: ["remove:ifAbsent:", "errorNotFound"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "remove:ifAbsent:", category: '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},smalltalk.Collection)})}, args: ["anObject", "aBlock"], source: "remove: anObject ifAbsent: aBlock\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "select:", category: '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)})})); $2=_st(stream)._contents(); return $2; }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,stream:stream},smalltalk.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:", "nextPut:", "value:", "contents"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "select:thenCollect:", category: '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); if(smalltalk.assert($1)){ return _st(stream)._nextPut_(_st(collectBlock)._value_(each)); }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=_st(stream)._contents(); return $2; }, function($ctx1) {$ctx1.fill(self,"select:thenCollect:",{selectBlock:selectBlock,collectBlock:collectBlock,stream:stream},smalltalk.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:", "nextPut:", "value:", "contents"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassResponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.Collection)})}, args: [], source: "size\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.Collection); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "collection"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Collection.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'collection'", messageSends: [], referencedClasses: [] }), smalltalk.Collection.klass); smalltalk.addMethod( smalltalk.method({ selector: "new:", category: '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},smalltalk.Collection.klass)})}, args: ["anInteger"], source: "new: anInteger\x0a\x09^self new", messageSends: ["new"], referencedClasses: [] }), smalltalk.Collection.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:", category: '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},smalltalk.Collection.klass)})}, args: ["anObject"], source: "with: anObject\x0a\x09\x09^self new\x0a\x09\x09add: anObject;\x0a\x09\x09yourself", messageSends: ["add:", "new", "yourself"], referencedClasses: [] }), smalltalk.Collection.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:with:", category: '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); _st($2)._add_(anotherObject); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"with:with:",{anObject:anObject,anotherObject:anotherObject},smalltalk.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: [] }), smalltalk.Collection.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:with:with:", category: '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); _st($2)._add_(secondObject); _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},smalltalk.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: [] }), smalltalk.Collection.klass); smalltalk.addMethod( smalltalk.method({ selector: "withAll:", category: '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},smalltalk.Collection.klass)})}, args: ["aCollection"], source: "withAll: aCollection\x0a\x09\x09^self new\x0a\x09\x09addAll: aCollection;\x0a\x09\x09yourself", messageSends: ["addAll:", "new", "yourself"], referencedClasses: [] }), smalltalk.Collection.klass); smalltalk.addClass('IndexableCollection', smalltalk.Collection, [], 'Kernel-Collections'); smalltalk.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:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"at:",{anIndex:anIndex},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (anIndex,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassReponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},smalltalk.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 subclassReponsibility", messageSends: ["subclassReponsibility"], referencedClasses: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:",{anIndex:anIndex,aBlock:aBlock},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:ifAbsent:", category: '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},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: 'accessing', fn: function (anIndex,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassReponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"at:put:",{anIndex:anIndex,anObject:anObject},smalltalk.IndexableCollection)})}, args: ["anIndex", "anObject"], source: "at: anIndex put: anObject\x0a\x09\x22Store anObject under the given index in the receiver.\x22\x0a\x0a\x09self subclassReponsibility", messageSends: ["subclassReponsibility"], referencedClasses: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"indexOf:",{anObject:anObject},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:ifAbsent:", category: '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},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "with:do:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"with:do:",{anotherCollection:anotherCollection,aBlock:aBlock},smalltalk.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: [] }), smalltalk.IndexableCollection); smalltalk.addMethod( smalltalk.method({ selector: "withIndexDo:", category: 'enumarating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassReponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"withIndexDo:",{aBlock:aBlock},smalltalk.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 subclassReponsibility", messageSends: ["subclassReponsibility"], referencedClasses: [] }), smalltalk.IndexableCollection); smalltalk.addClass('HashedCollection', smalltalk.IndexableCollection, [], 'Kernel-Collections'); smalltalk.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: ",", category: 'copying', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldNotImplement(); return self}, function($ctx1) {$ctx1.fill(self,",",{aCollection:aCollection},smalltalk.HashedCollection)})}, args: ["aCollection"], source: ", aCollection\x0a\x09self shouldNotImplement", messageSends: ["shouldNotImplement"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aHashedCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(self._class()).__eq(_st(aHashedCollection)._class()); if(! smalltalk.assert($1)){ return false; }; $2=_st(self._size()).__eq(_st(aHashedCollection)._size()); if(! smalltalk.assert($2)){ return false; }; $3=_st(self._associations()).__eq(_st(aHashedCollection)._associations()); return $3; }, function($ctx1) {$ctx1.fill(self,"=",{aHashedCollection:aHashedCollection},smalltalk.HashedCollection)})}, args: ["aHashedCollection"], source: "= aHashedCollection\x0a\x09self class = aHashedCollection class ifFalse: [^false].\x0a\x09self size = aHashedCollection size ifFalse: [^false].\x0a\x09^self associations = aHashedCollection associations", messageSends: ["ifFalse:", "=", "class", "size", "associations"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "add:", category: '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},smalltalk.HashedCollection)})}, args: ["anAssociation"], source: "add: anAssociation\x0a\x09self at: anAssociation key put: anAssociation value", messageSends: ["at:put:", "key", "value"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "addAll:", category: 'adding/removing', fn: function (aHashedCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; smalltalk.HashedCollection.superclass.fn.prototype._addAll_.apply(_st(self), [_st(aHashedCollection)._associations()]); $1=aHashedCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"addAll:",{aHashedCollection:aHashedCollection},smalltalk.HashedCollection)})}, args: ["aHashedCollection"], source: "addAll: aHashedCollection\x0a\x09super addAll: aHashedCollection associations.\x0a\x09^aHashedCollection", messageSends: ["addAll:", "associations"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "asDictionary", category: 'converting', fn: function (){ var self=this; function $Dictionary(){return smalltalk.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",{},smalltalk.HashedCollection)})}, args: [], source: "asDictionary\x0a\x09^Dictionary from: self associations", messageSends: ["from:", "associations"], referencedClasses: ["Dictionary"] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; var c; return smalltalk.withContext(function($ctx1) { var $1; c=_st(self._class())._new(); self._keysAndValuesDo_((function(key,value){ return smalltalk.withContext(function($ctx2) { return _st(c)._at_put_(key,_st(value)._asJSON()); }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1)})})); $1=c; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{c:c},smalltalk.HashedCollection)})}, args: [], source: "asJSON\x0a\x09| c |\x0a\x09c := self class new.\x0a\x09self keysAndValuesDo: [:key :value |\x0a\x09\x09c at: key put: value asJSON].\x0a\x09^c", messageSends: ["new", "class", "keysAndValuesDo:", "at:put:", "asJSON"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "associations", category: '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=associations; return $1; }, function($ctx1) {$ctx1.fill(self,"associations",{associations:associations},smalltalk.HashedCollection)})}, args: [], source: "associations\x0a\x09| associations |\x0a\x09associations := #().\x0a\x09self associationsDo: [:each | associations add: each].\x0a\x09^associations", messageSends: ["associationsDo:", "add:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "associationsDo:", category: 'enumerating', fn: function (aBlock){ var self=this; function $Association(){return smalltalk.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)})})); return self}, function($ctx1) {$ctx1.fill(self,"associationsDo:",{aBlock:aBlock},smalltalk.HashedCollection)})}, 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"] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (aKey,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._includesKey_(aKey); $1=_st($2)._ifTrue_ifFalse_((function(){ return smalltalk.withContext(function($ctx2) { return self._basicAt_(aKey); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aKey:aKey,aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["aKey", "aBlock"], source: "at: aKey ifAbsent: aBlock\x0a\x09^(self includesKey: aKey)\x0a\x09\x09ifTrue: [self basicAt: aKey]\x0a\x09\x09ifFalse: aBlock", messageSends: ["ifTrue:ifFalse:", "basicAt:", "includesKey:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsentPut:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"at:ifAbsentPut:",{aKey:aKey,aBlock:aBlock},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:ifAbsent:", category: 'accessing', fn: function (aKey,aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._includesKey_(aKey); $1=_st($2)._ifTrue_ifFalse_((function(){ return smalltalk.withContext(function($ctx2) { return _st(aBlock)._value_(self._at_(aKey)); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),anotherBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{aKey:aKey,aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.HashedCollection)})}, 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 with the value associated with the key,\x0a\x09otherwise answer the value of absentBlock.\x22\x0a\x09^(self includesKey: aKey)\x0a\x09\x09ifTrue: [ aBlock value: (self at: aKey) ]\x0a\x09\x09ifFalse: anotherBlock", messageSends: ["ifTrue:ifFalse:", "value:", "at:", "includesKey:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: '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},smalltalk.HashedCollection)})}, args: ["aKey", "aValue"], source: "at: aKey put: aValue\x0a\x09^self basicAt: aKey put: aValue", messageSends: ["basicAt:put:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "collect:", category: '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=newDict; return $1; }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock,newDict:newDict},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: '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=copy; return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{copy:copy},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "detect:ifNone:", category: '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},smalltalk.HashedCollection)})}, args: ["aBlock", "anotherBlock"], source: "detect: aBlock ifNone: anotherBlock\x0a\x09^self values detect: aBlock ifNone: anotherBlock", messageSends: ["detect:ifNone:", "values"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: '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},smalltalk.HashedCollection)})}, args: ["aBlock"], source: "do: aBlock\x0a\x09self valuesDo: aBlock", messageSends: ["valuesDo:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "includes:", category: '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},smalltalk.HashedCollection)})}, args: ["anObject"], source: "includes: anObject\x0a\x09^self values includes: anObject", messageSends: ["includes:", "values"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "includesKey:", category: 'testing', fn: function (aKey){ var self=this; return smalltalk.withContext(function($ctx1) { return self.hasOwnProperty(aKey); return self}, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},smalltalk.HashedCollection)})}, args: ["aKey"], source: "includesKey: aKey\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:ifAbsent:", category: '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)})}),aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"indexOf:ifAbsent:",{anObject:anObject,aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["anObject", "aBlock"], source: "indexOf: anObject ifAbsent: aBlock\x0a\x0a\x09^ self keys detect: [ :each | (self at: each) = anObject ] ifNone: aBlock", messageSends: ["detect:ifNone:", "=", "at:", "keys"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "keyAtValue:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"keyAtValue:",{anObject:anObject},smalltalk.HashedCollection)})}, args: ["anObject"], source: "keyAtValue: anObject\x0a\x09^ self keyAtValue: anObject ifAbsent: [ self errorNotFound ]", messageSends: ["keyAtValue:ifAbsent:", "errorNotFound"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "keyAtValue:ifAbsent:", category: '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},smalltalk.HashedCollection)})}, args: ["anObject", "aBlock"], source: "keyAtValue: anObject ifAbsent: aBlock\x0a\x09^ self indexOf: anObject ifAbsent: aBlock", messageSends: ["indexOf:ifAbsent:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "keys", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { if ('function'===typeof Object.keys) return Object.keys(self); var keys = []; for(var i in self) { if(self.hasOwnProperty(i)) { keys.push(i); } }; return keys; ; return self}, function($ctx1) {$ctx1.fill(self,"keys",{},smalltalk.HashedCollection)})}, args: [], source: "keys\x0a\x09<\x0a\x09\x09if ('function'===typeof Object.keys) return Object.keys(self);\x0a\x09\x09var keys = [];\x0a\x09\x09for(var i in self) {\x0a\x09\x09\x09if(self.hasOwnProperty(i)) {\x0a\x09\x09\x09\x09keys.push(i);\x0a\x09\x09\x09}\x0a\x09\x09};\x0a\x09\x09return keys;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "keysAndValuesDo:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["aBlock"], source: "keysAndValuesDo: aBlock\x0a\x09self keysDo: [:each |\x0a\x09\x09aBlock value: each value: (self at: each)]", messageSends: ["keysDo:", "value:value:", "at:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "keysDo:", category: '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},smalltalk.HashedCollection)})}, args: ["aBlock"], source: "keysDo: aBlock\x0a\x09self keys do: aBlock", messageSends: ["do:", "keys"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.HashedCollection.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); _st(aStream)._nextPutAll_(" ("); _st(self._associations())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._printOn_(aStream); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(aStream)._nextPutAll_(" , "); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(aStream)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "remove:ifAbsent:", category: '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},smalltalk.HashedCollection)})}, args: ["aKey", "aBlock"], source: "remove: aKey ifAbsent: aBlock\x0a\x09^self removeKey: aKey ifAbsent: aBlock", messageSends: ["removeKey:ifAbsent:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "removeKey:", category: '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},smalltalk.HashedCollection)})}, args: ["aKey"], source: "removeKey: aKey\x0a\x09^self remove: aKey", messageSends: ["remove:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "removeKey:ifAbsent:", category: 'adding/removing', 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._basicDelete_(aKey); } else { $1=_st(aBlock)._value(); }; return $1; }, function($ctx1) {$ctx1.fill(self,"removeKey:ifAbsent:",{aKey:aKey,aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["aKey", "aBlock"], source: "removeKey: aKey ifAbsent: aBlock\x0a\x09^(self includesKey: aKey)\x0a\x09\x09ifFalse: [aBlock value]\x0a\x09\x09ifTrue: [self basicDelete: aKey]", messageSends: ["ifFalse:ifTrue:", "value", "basicDelete:", "includesKey:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "select:", category: '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)})})); $2=newDict; return $2; }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,newDict:newDict},smalltalk.HashedCollection)})}, 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:", "at:put:", "value:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: '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=copy; return $1; }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{copy:copy},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "size", category: '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",{},smalltalk.HashedCollection)})}, args: [], source: "size\x0a\x09^self keys size", messageSends: ["size", "keys"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "values", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self._keys().map(function(key){ return self._at_(key); }); ; return self}, function($ctx1) {$ctx1.fill(self,"values",{},smalltalk.HashedCollection)})}, 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: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "valuesDo:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._values())._do_((function(value){ return smalltalk.withContext(function($ctx2) { return _st(aBlock)._value_(value); }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"valuesDo:",{aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["aBlock"], source: "valuesDo: aBlock\x0a\x09self values do: [ :value | aBlock value: value ]", messageSends: ["do:", "value:", "values"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "withIndexDo:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"withIndexDo:",{aBlock:aBlock},smalltalk.HashedCollection)})}, args: ["aBlock"], source: "withIndexDo: aBlock\x0a\x09self keysAndValuesDo: [ :key :value | aBlock value: value value: key ]", messageSends: ["keysAndValuesDo:", "value:value:"], referencedClasses: [] }), smalltalk.HashedCollection); smalltalk.addMethod( smalltalk.method({ selector: "from:", category: '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=newCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"from:",{aCollection:aCollection,newCollection:newCollection},smalltalk.HashedCollection.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: [] }), smalltalk.HashedCollection.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromPairs:", category: '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},smalltalk.HashedCollection.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: [] }), smalltalk.HashedCollection.klass); smalltalk.addMethod( smalltalk.method({ selector: "newFromPairs:", category: 'instance creation', fn: function (aCollection){ var self=this; var newCollection; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(_st(aCollection)._size())._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) { return _st(newCollection)._at_put_(_st(aCollection)._at_(each),_st(aCollection)._at_(_st(each).__plus((1)))); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=newCollection; return $2; }, function($ctx1) {$ctx1.fill(self,"newFromPairs:",{aCollection:aCollection,newCollection:newCollection},smalltalk.HashedCollection.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:", "error:", "even", "size", "new", "do:", "at:put:", "at:", "+", "to:by:"], referencedClasses: [] }), smalltalk.HashedCollection.klass); smalltalk.addClass('Dictionary', smalltalk.HashedCollection, ['keys', 'values'], 'Kernel-Collections'); smalltalk.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: "asHashedCollection", category: 'converting', fn: function (){ var self=this; function $HashedCollection(){return smalltalk.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",{},smalltalk.Dictionary)})}, args: [], source: "asHashedCollection\x0a\x09^ HashedCollection from: self associations", messageSends: ["from:", "associations"], referencedClasses: ["HashedCollection"] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._asHashedCollection())._asJSON(); return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.Dictionary)})}, args: [], source: "asJSON\x0a\x09^ self asHashedCollection asJSON", messageSends: ["asJSON", "asHashedCollection"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (aKey,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var index = self._positionOfKey_(aKey); return index >=0 ? self['@values'][index] : aBlock._value(); ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aKey:aKey,aBlock:aBlock},smalltalk.Dictionary)})}, 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: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: 'accessing', fn: function (aKey,aValue){ var self=this; return smalltalk.withContext(function($ctx1) { var index = self._positionOfKey_(aKey); if(index === -1) { var keys = self['@keys']; index = keys.length; keys.push(aKey); } return self['@values'][index] = aValue; ; return self}, function($ctx1) {$ctx1.fill(self,"at:put:",{aKey:aKey,aValue:aValue},smalltalk.Dictionary)})}, 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: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "includesKey:", category: 'testing', fn: function (aKey){ var self=this; return smalltalk.withContext(function($ctx1) { return self._positionOfKey_(aKey) >= 0; ; return self}, function($ctx1) {$ctx1.fill(self,"includesKey:",{aKey:aKey},smalltalk.Dictionary)})}, args: ["aKey"], source: "includesKey: aKey\x0a\x09< return self._positionOfKey_(aKey) >>= 0; >", messageSends: [], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:ifAbsent:", category: '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)})})); $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},smalltalk.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: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.Dictionary.superclass.fn.prototype._initialize.apply(_st(self), []); self["@keys"]=[]; self["@values"]=[]; return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Dictionary)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09keys := #().\x0a\x09values := #()", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "keys", category: '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",{},smalltalk.Dictionary)})}, args: [], source: "keys\x0a\x09^ keys copy", messageSends: ["copy"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "keysAndValuesDo:", category: '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},smalltalk.Dictionary)})}, args: ["aBlock"], source: "keysAndValuesDo: aBlock\x0a\x09^ keys with: values do: aBlock", messageSends: ["with:do:"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "keysDo:", category: '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},smalltalk.Dictionary)})}, args: ["aBlock"], source: "keysDo: aBlock\x0a\x09^ keys do: aBlock", messageSends: ["do:"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "positionOfKey:", category: 'private', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var keys = self['@keys']; for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "removeKey:ifAbsent:", category: 'adding/removing', fn: function (aKey,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var index = self._positionOfKey_(aKey); if(index === -1) { return aBlock._value() } else { var keys = self['@keys'], values = self['@values']; var value = values[index], l = keys.length; keys[index] = keys[l-1]; keys.pop(); values[index] = values[l-1]; values.pop(); return value; } ; return self}, function($ctx1) {$ctx1.fill(self,"removeKey:ifAbsent:",{aKey:aKey,aBlock:aBlock},smalltalk.Dictionary)})}, 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: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "values", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@values"]; return $1; }, function($ctx1) {$ctx1.fill(self,"values",{},smalltalk.Dictionary)})}, args: [], source: "values\x0a\x09^ values", messageSends: [], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addMethod( smalltalk.method({ selector: "valuesDo:", category: '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},smalltalk.Dictionary)})}, args: ["aBlock"], source: "valuesDo: aBlock\x0a\x09^ values do: aBlock", messageSends: ["do:"], referencedClasses: [] }), smalltalk.Dictionary); smalltalk.addClass('SequenceableCollection', smalltalk.IndexableCollection, [], 'Kernel-Collections'); smalltalk.SequenceableCollection.comment="I am an IndexableCollection\x0awith numeric indexes starting with 1."; smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { $1=_st(_st(self._class()).__eq(_st(aCollection)._class()))._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._size()).__eq(_st(aCollection)._size()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(! smalltalk.assert($1)){ return false; }; self._withIndexDo_((function(each,i){ return smalltalk.withContext(function($ctx2) { $2=_st(_st(aCollection)._at_(i)).__eq(each); if(! smalltalk.assert($2)){ throw $early=[false]; }; }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1)})})); return true; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"=",{aCollection:aCollection},smalltalk.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:", "=", "size", "class", "withIndexDo:", "at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "addLast:", category: '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},smalltalk.SequenceableCollection)})}, args: ["anObject"], source: "addLast: anObject\x0a\x09self add: anObject", messageSends: ["add:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "allButFirst", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "allButFirst\x0a\x09^self copyFrom: 2 to: self size", messageSends: ["copyFrom:to:", "size"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "allButLast", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "allButLast\x0a\x09^self copyFrom: 1 to: self size - 1", messageSends: ["copyFrom:to:", "-", "size"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "atRandom", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "atRandom\x0a\x09^ self at: self size atRandom", messageSends: ["at:", "atRandom", "size"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "copyFrom:to:", category: '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=newCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex,range:range,newCollection:newCollection},smalltalk.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:", "size", "class", "withIndexDo:", "at:put:", "at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: '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=newCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{newCollection:newCollection},smalltalk.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:", "size", "class", "withIndexDo:", "at:put:", "deepCopy"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "detect:ifNone:", category: 'enumerating', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i = 0; i < self.length; i++) if(aBlock._value_(self[i])) return self[i]; return anotherBlock._value(); ; return self}, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.SequenceableCollection)})}, args: ["aBlock", "anotherBlock"], source: "detect: aBlock ifNone: anotherBlock\x0a\x09<\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: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "first", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "first\x0a\x09^self at: 1", messageSends: ["at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "first:", category: 'accessing', fn: function (n){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._copyFrom_to_((1),n); return $1; }, function($ctx1) {$ctx1.fill(self,"first:",{n:n},smalltalk.SequenceableCollection)})}, args: ["n"], source: "first: n\x0a\x09\x22Answer the first n elements of the receiver.\x0a\x09Raise an error if there are not enough elements.\x22\x0a\x0a\x09^ self copyFrom: 1 to: n", messageSends: ["copyFrom:to:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "fourth", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "fourth\x0a\x09^self at: 4", messageSends: ["at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "includes:", category: '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)})})))._notNil(); return $1; }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},smalltalk.SequenceableCollection)})}, args: ["anObject"], source: "includes: anObject\x0a\x09^(self indexOf: anObject ifAbsent: [nil]) notNil", messageSends: ["notNil", "indexOf:ifAbsent:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:ifAbsent:", category: 'accessing', fn: function (anObject,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:startingAt:", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"indexOf:startingAt:",{anObject:anObject,start:start},smalltalk.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: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "indexOf:startingAt:ifAbsent:", category: 'accessing', fn: function (anObject,start,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=start-1;i", messageSends: [], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "last", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "last\x0a\x09^self at: self size", messageSends: ["at:", "size"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "newStream", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "newStream\x0a\x09^self streamClass on: self", messageSends: ["on:", "streamClass"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "readStream", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._stream(); return $1; }, function($ctx1) {$ctx1.fill(self,"readStream",{},smalltalk.SequenceableCollection)})}, args: [], source: "readStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^self stream", messageSends: ["stream"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "removeLast", category: 'adding/removing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._remove_(self._last()); return self}, function($ctx1) {$ctx1.fill(self,"removeLast",{},smalltalk.SequenceableCollection)})}, args: [], source: "removeLast\x0a\x09self remove: self last", messageSends: ["remove:", "last"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "reversed", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassResponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"reversed",{},smalltalk.SequenceableCollection)})}, args: [], source: "reversed\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "second", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "second\x0a\x09^self at: 2", messageSends: ["at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: '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=newCollection; return $1; }, function($ctx1) {$ctx1.fill(self,"shallowCopy",{newCollection:newCollection},smalltalk.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:", "size", "class", "withIndexDo:", "at:put:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "stream", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._newStream(); return $1; }, function($ctx1) {$ctx1.fill(self,"stream",{},smalltalk.SequenceableCollection)})}, args: [], source: "stream\x0a\x09^self newStream", messageSends: ["newStream"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "streamClass", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "streamClass\x0a\x09^self class streamClass", messageSends: ["streamClass", "class"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "third", category: '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",{},smalltalk.SequenceableCollection)})}, args: [], source: "third\x0a\x09^self at: 3", messageSends: ["at:"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "with:do:", category: 'enumerating', fn: function (anotherCollection,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "withIndexDo:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "writeStream", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._stream(); return $1; }, function($ctx1) {$ctx1.fill(self,"writeStream",{},smalltalk.SequenceableCollection)})}, args: [], source: "writeStream\x0a\x09\x22For Pharo compatibility\x22\x0a\x09\x0a\x09^self stream", messageSends: ["stream"], referencedClasses: [] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "streamClass", category: 'accessing', fn: function (){ var self=this; function $Stream(){return smalltalk.Stream||(typeof Stream=="undefined"?nil:Stream)} return smalltalk.withContext(function($ctx1) { var $1; $1=$Stream(); return $1; }, function($ctx1) {$ctx1.fill(self,"streamClass",{},smalltalk.SequenceableCollection.klass)})}, args: [], source: "streamClass\x0a\x09\x09^Stream", messageSends: [], referencedClasses: ["Stream"] }), smalltalk.SequenceableCollection.klass); smalltalk.addMethod( smalltalk.method({ selector: "streamContents:", category: '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},smalltalk.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:", "new", "streamClass", "value:", "contents"], referencedClasses: [] }), smalltalk.SequenceableCollection.klass); smalltalk.addClass('Array', smalltalk.SequenceableCollection, [], 'Kernel-Collections'); smalltalk.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:", category: 'adding/removing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self.push(anObject); return anObject;; return self}, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},smalltalk.Array)})}, args: ["anObject"], source: "add: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: '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)})})))._join_(", "))).__comma("]"); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.Array)})}, args: [], source: "asJavascript\x0a\x09^'[', ((self collect: [:each | each asJavascript]) join: ', '), ']'", messageSends: [",", "join:", "collect:", "asJavascript"], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (anIndex,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { if((anIndex < 1) || (self.length < anIndex)) {return aBlock._value()}; return self[anIndex - 1]; ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},smalltalk.Array)})}, args: ["anIndex", "aBlock"], source: "at: anIndex ifAbsent: aBlock\x0a\x09<\x0a\x09\x09if((anIndex < 1) || (self.length < anIndex)) {return aBlock._value()};\x0a\x09\x09return self[anIndex - 1];\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:ifAbsent:", category: 'accessing', fn: function (anIndex,aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { return anIndex < 1 || self.length < anIndex ? anotherBlock._value() : aBlock._value_(self[anIndex - 1]);; return self}, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{anIndex:anIndex,aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Array)})}, args: ["anIndex", "aBlock", "anotherBlock"], source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: 'accessing', fn: function (anIndex,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { return self[anIndex - 1] = anObject; return self}, function($ctx1) {$ctx1.fill(self,"at:put:",{anIndex:anIndex,anObject:anObject},smalltalk.Array)})}, args: ["anIndex", "anObject"], source: "at: anIndex put: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "collect:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { return self.map(function(each) {return aBlock._value_(each)}); return self}, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock},smalltalk.Array)})}, args: ["aBlock"], source: "collect: aBlock\x0a\x09\x22Optimized version\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "join:", category: 'enumerating', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.join(aString); return self}, function($ctx1) {$ctx1.fill(self,"join:",{aString:aString},smalltalk.Array)})}, args: ["aString"], source: "join: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.Array.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); _st(aStream)._nextPutAll_(" ("); self._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._printOn_(aStream); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(aStream)._nextPutAll_(" "); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(aStream)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.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: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "remove:ifAbsent:", category: 'adding/removing', fn: function (anObject,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "removeFrom:to:", category: 'adding/removing', fn: function (aNumber,anotherNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self.splice(aNumber -1, anotherNumber - aNumber + 1); return self}, function($ctx1) {$ctx1.fill(self,"removeFrom:to:",{aNumber:aNumber,anotherNumber:anotherNumber},smalltalk.Array)})}, args: ["aNumber", "anotherNumber"], source: "removeFrom: aNumber to: anotherNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "removeIndex:", category: 'adding/removing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self.splice(anInteger - 1, 1); return self}, function($ctx1) {$ctx1.fill(self,"removeIndex:",{anInteger:anInteger},smalltalk.Array)})}, args: ["anInteger"], source: "removeIndex: anInteger\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "reversed", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self._copy().reverse(); return self}, function($ctx1) {$ctx1.fill(self,"reversed",{},smalltalk.Array)})}, args: [], source: "reversed\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "select:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var result = self.klass._new(); for(var i=0; i", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.length; return self}, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.Array)})}, args: [], source: "size\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "sort", category: '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",{},smalltalk.Array)})}, args: [], source: "sort\x0a\x09^self basicPerform: 'sort'", messageSends: ["basicPerform:"], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "sort:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { return self.sort(function(a, b) { if(aBlock._value_value_(a,b)) {return -1} else {return 1} }) ; return self}, function($ctx1) {$ctx1.fill(self,"sort:",{aBlock:aBlock},smalltalk.Array)})}, 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: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "sorted", category: '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",{},smalltalk.Array)})}, args: [], source: "sorted\x0a\x09^self copy sort", messageSends: ["sort", "copy"], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "sorted:", category: '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},smalltalk.Array)})}, args: ["aBlock"], source: "sorted: aBlock\x0a\x09^self copy sort: aBlock", messageSends: ["sort:", "copy"], referencedClasses: [] }), smalltalk.Array); smalltalk.addMethod( smalltalk.method({ selector: "new:", category: 'instance creation', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { return new Array(anInteger); return self}, function($ctx1) {$ctx1.fill(self,"new:",{anInteger:anInteger},smalltalk.Array.klass)})}, args: ["anInteger"], source: "new: anInteger\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Array.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:", category: '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},smalltalk.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: [] }), smalltalk.Array.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:with:", category: '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); _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},smalltalk.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: [] }), smalltalk.Array.klass); smalltalk.addMethod( smalltalk.method({ selector: "with:with:with:", category: '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); _st($2)._at_put_((2),anObject2); _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},smalltalk.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: [] }), smalltalk.Array.klass); smalltalk.addMethod( smalltalk.method({ selector: "withAll:", category: '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=instance; return $1; }, function($ctx1) {$ctx1.fill(self,"withAll:",{aCollection:aCollection,instance:instance,index:index},smalltalk.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: [] }), smalltalk.Array.klass); smalltalk.addClass('CharacterArray', smalltalk.SequenceableCollection, [], 'Kernel-Collections'); smalltalk.CharacterArray.comment="I am the abstract superclass of string-like collections."; smalltalk.addMethod( smalltalk.method({ selector: ",", category: 'copying', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._asString()).__comma(_st(aString)._asString()); return $1; }, function($ctx1) {$ctx1.fill(self,",",{aString:aString},smalltalk.CharacterArray)})}, args: ["aString"], source: ", aString\x0a\x09^self asString, aString asString", messageSends: [",", "asString"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "add:", category: '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},smalltalk.CharacterArray)})}, args: ["anObject"], source: "add: anObject\x0a\x09self errorReadOnly", messageSends: ["errorReadOnly"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "asLowercase", category: '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",{},smalltalk.CharacterArray)})}, args: [], source: "asLowercase\x0a\x09^self class fromString: self asString asLowercase", messageSends: ["fromString:", "asLowercase", "asString", "class"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "asNumber", category: '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",{},smalltalk.CharacterArray)})}, args: [], source: "asNumber\x0a\x09^self asString asNumber", messageSends: ["asNumber", "asString"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._subclassResponsibility(); return $1; }, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.CharacterArray)})}, args: [], source: "asString\x0a\x09^self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "asSymbol", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._asString(); return $1; }, function($ctx1) {$ctx1.fill(self,"asSymbol",{},smalltalk.CharacterArray)})}, args: [], source: "asSymbol\x0a\x09^self asString", messageSends: ["asString"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "asUppercase", category: '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",{},smalltalk.CharacterArray)})}, args: [], source: "asUppercase\x0a\x09^self class fromString: self asString asUppercase", messageSends: ["fromString:", "asUppercase", "asString", "class"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: '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},smalltalk.CharacterArray)})}, args: ["anIndex", "anObject"], source: "at: anIndex put: anObject\x0a\x09self errorReadOnly", messageSends: ["errorReadOnly"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "errorReadOnly", category: '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",{},smalltalk.CharacterArray)})}, args: [], source: "errorReadOnly\x0a\x09self error: 'Object is read-only'", messageSends: ["error:"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: '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},smalltalk.CharacterArray)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09self asString printOn: aStream", messageSends: ["printOn:", "asString"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "putOn:", category: '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},smalltalk.CharacterArray)})}, args: ["aStream"], source: "putOn: aStream\x0a\x09aStream nextPutString: self", messageSends: ["nextPutString:"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "remove:", category: '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},smalltalk.CharacterArray)})}, args: ["anObject"], source: "remove: anObject\x0a\x09self errorReadOnly", messageSends: ["errorReadOnly"], referencedClasses: [] }), smalltalk.CharacterArray); smalltalk.addMethod( smalltalk.method({ selector: "fromString:", category: '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},smalltalk.CharacterArray.klass)})}, args: ["aString"], source: "fromString: aString\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.CharacterArray.klass); smalltalk.addClass('String', smalltalk.CharacterArray, [], 'Kernel-Collections'); smalltalk.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: ",", category: 'copying', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self + aString; return self}, function($ctx1) {$ctx1.fill(self,",",{aString:aString},smalltalk.String)})}, args: ["aString"], source: ", aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "<", category: 'comparing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self) < aString._asString(); return self}, function($ctx1) {$ctx1.fill(self,"<",{aString:aString},smalltalk.String)})}, args: ["aString"], source: "< aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "<=", category: 'comparing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self) <= aString._asString(); return self}, function($ctx1) {$ctx1.fill(self,"<=",{aString:aString},smalltalk.String)})}, args: ["aString"], source: "<= aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { if(typeof aString === 'undefined') { return false } if(!aString._isString || ! aString._isString()) { return false; } return String(self) === String(aString) ; return self}, function($ctx1) {$ctx1.fill(self,"=",{aString:aString},smalltalk.String)})}, args: ["aString"], source: "= aString\x0a\x09<\x0a\x09\x09if(typeof aString === 'undefined') { return false }\x0a\x09\x09if(!aString._isString || ! aString._isString()) {\x0a\x09\x09\x09return false;\x0a\x09\x09}\x0a\x09\x09return String(self) === String(aString)\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "==", category: '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},smalltalk.String)})}, args: ["aString"], source: "== aString\x0a\x09^self = aString", messageSends: ["="], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: ">", category: 'comparing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self) > aString._asString(); return self}, function($ctx1) {$ctx1.fill(self,">",{aString:aString},smalltalk.String)})}, args: ["aString"], source: "> aString\x0a\x09> aString._asString()>", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: ">=", category: 'comparing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self) >= aString._asString(); return self}, function($ctx1) {$ctx1.fill(self,">=",{aString:aString},smalltalk.String)})}, args: ["aString"], source: ">= aString\x0a\x09>= aString._asString()>", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asJSON", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asJSON",{},smalltalk.String)})}, args: [], source: "asJSON\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asJavascript", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { if(self.search(/^[a-zA-Z0-9_:.$ ]*$/) == -1) return "\"" + self.replace(/[\x00-\x1f"\\\x7f-\x9f]/g, function(ch){var c=ch.charCodeAt(0);return "\\x"+("0"+c.toString(16)).slice(-2)}) + "\""; else return "\"" + self + "\""; ; return self}, function($ctx1) {$ctx1.fill(self,"asJavascript",{},smalltalk.String)})}, 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: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asLowercase", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toLowerCase(); return self}, function($ctx1) {$ctx1.fill(self,"asLowercase",{},smalltalk.String)})}, args: [], source: "asLowercase\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asMutator", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(self._last()).__eq(":"); if(! smalltalk.assert($1)){ $2=self.__comma(":"); return $2; }; $3=self; return $3; }, function($ctx1) {$ctx1.fill(self,"asMutator",{},smalltalk.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: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asNumber", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return Number(self); return self}, function($ctx1) {$ctx1.fill(self,"asNumber",{},smalltalk.String)})}, args: [], source: "asNumber\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asRegexp", category: 'converting', fn: function (){ var self=this; function $RegularExpression(){return smalltalk.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",{},smalltalk.String)})}, args: [], source: "asRegexp\x0a\x09^ RegularExpression fromString: self", messageSends: ["fromString:"], referencedClasses: ["RegularExpression"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asSelector", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.selector(self); return self}, function($ctx1) {$ctx1.fill(self,"asSelector",{},smalltalk.String)})}, args: [], source: "asSelector\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.String)})}, args: [], source: "asString\x0a\x09^self", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asSymbol", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"asSymbol",{},smalltalk.String)})}, args: [], source: "asSymbol\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asUppercase", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.toUpperCase(); return self}, function($ctx1) {$ctx1.fill(self,"asUppercase",{},smalltalk.String)})}, args: [], source: "asUppercase\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "asciiValue", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.charCodeAt(0);; return self}, function($ctx1) {$ctx1.fill(self,"asciiValue",{},smalltalk.String)})}, args: [], source: "asciiValue\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (anIndex,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { return String(self).charAt(anIndex - 1) || aBlock._value(); return self}, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{anIndex:anIndex,aBlock:aBlock},smalltalk.String)})}, args: ["anIndex", "aBlock"], source: "at: anIndex ifAbsent: aBlock\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:ifAbsent:", category: 'accessing', fn: function (anIndex,aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var result = String(self).charAt(anIndex - 1); return result ? aBlock._value_(result) : anotherBlock._value(); ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{anIndex:anIndex,aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.String)})}, args: ["anIndex", "aBlock", "anotherBlock"], source: "at: anIndex ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09<\x0a\x09\x09var result = String(self).charAt(anIndex - 1);\x0a\x09\x09return result ? aBlock._value_(result) : anotherBlock._value();\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "charCodeAt:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { return self.charCodeAt(anInteger - 1) ; return self}, function($ctx1) {$ctx1.fill(self,"charCodeAt:",{anInteger:anInteger},smalltalk.String)})}, args: ["anInteger"], source: "charCodeAt: anInteger\x0a\x09< return self.charCodeAt(anInteger - 1) >", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "copyFrom:to:", category: 'copying', fn: function (anIndex,anotherIndex){ var self=this; return smalltalk.withContext(function($ctx1) { return self.substring(anIndex - 1, anotherIndex); return self}, function($ctx1) {$ctx1.fill(self,"copyFrom:to:",{anIndex:anIndex,anotherIndex:anotherIndex},smalltalk.String)})}, args: ["anIndex", "anotherIndex"], source: "copyFrom: anIndex to: anotherIndex\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "crlfSanitized", category: 'converting', fn: function (){ var self=this; function $String(){return smalltalk.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",{},smalltalk.String)})}, args: [], source: "crlfSanitized\x0a\x09^self lines join: String lf", messageSends: ["join:", "lf", "lines"], referencedClasses: ["String"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "deepCopy", category: 'copying', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._shallowCopy(); return $1; }, function($ctx1) {$ctx1.fill(self,"deepCopy",{},smalltalk.String)})}, args: [], source: "deepCopy\x0a\x09^self shallowCopy", messageSends: ["shallowCopy"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "escaped", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return escape(self); return self}, function($ctx1) {$ctx1.fill(self,"escaped",{},smalltalk.String)})}, args: [], source: "escaped\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "includesSubString:", category: 'testing', fn: function (subString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.indexOf(subString) != -1 ; return self}, function($ctx1) {$ctx1.fill(self,"includesSubString:",{subString:subString},smalltalk.String)})}, args: ["subString"], source: "includesSubString: subString\x0a\x09< return self.indexOf(subString) != -1 >", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.String)})}, args: [], source: "isImmutable\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "isString", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isString",{},smalltalk.String)})}, args: [], source: "isString\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "isVowel", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"isVowel",{},smalltalk.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:", "includes:", "asLowercase", "=", "size"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "join:", category: 'split join', fn: function (aCollection){ var self=this; function $String(){return smalltalk.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()); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}),(function(){ return smalltalk.withContext(function($ctx3) { return _st(stream)._nextPutAll_(self); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({stream:stream},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"join:",{aCollection:aCollection},smalltalk.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"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "lineIndicesDo:", category: 'split join', fn: function (aBlock){ var self=this; var cr,lf,start,sz,nextLF,nextCR; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; var $early={}; try { start=(1); sz=self._size(); cr=_st($String())._cr(); nextCR=self._indexOf_startingAt_(cr,(1)); lf=_st($String())._lf(); nextLF=self._indexOf_startingAt_(lf,(1)); _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(start).__lt_eq(sz); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { $1=_st(_st(nextLF).__eq((0)))._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(nextCR).__eq((0)); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); if(smalltalk.assert($1)){ _st(aBlock)._value_value_value_(start,sz,sz); $2=self; throw $early=[$2]; }; $3=_st(_st(nextCR).__eq((0)))._or_((function(){ return smalltalk.withContext(function($ctx3) { return _st((0).__lt(nextLF))._and_((function(){ return smalltalk.withContext(function($ctx4) { return _st(nextLF).__lt(nextCR); }, function($ctx4) {$ctx4.fillBlock({},$ctx3)})})); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); if(smalltalk.assert($3)){ _st(aBlock)._value_value_value_(start,_st(nextLF).__minus((1)),nextLF); start=(1).__plus(nextLF); start; nextLF=self._indexOf_startingAt_(lf,start); return nextLF; } else { $4=_st((1).__plus(nextCR)).__eq(nextLF); if(smalltalk.assert($4)){ _st(aBlock)._value_value_value_(start,_st(nextCR).__minus((1)),nextLF); start=(1).__plus(nextLF); start; nextCR=self._indexOf_startingAt_(cr,start); nextCR; nextLF=self._indexOf_startingAt_(lf,start); 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)})})); 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},smalltalk.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:", "value:value:value:", "and:", "=", "ifTrue:ifFalse:", "-", "+", "or:", "<", "<="], referencedClasses: ["String"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "lineNumber:", category: 'split join', fn: function (anIndex){ var self=this; var lineCount; return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { lineCount=(0); self._lineIndicesDo_((function(start,endWithoutDelimiters,end){ return smalltalk.withContext(function($ctx2) { lineCount=_st(lineCount).__plus((1)); $1=_st(lineCount).__eq(anIndex); if(smalltalk.assert($1)){ $2=self._copyFrom_to_(start,endWithoutDelimiters); throw $early=[$2]; }; }, function($ctx2) {$ctx2.fillBlock({start:start,endWithoutDelimiters:endWithoutDelimiters,end:end},$ctx1)})})); return nil; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"lineNumber:",{anIndex:anIndex,lineCount:lineCount},smalltalk.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: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "lines", category: 'split join', fn: function (){ var self=this; var lines; function $Array(){return smalltalk.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=lines; return $1; }, function($ctx1) {$ctx1.fill(self,"lines",{lines:lines},smalltalk.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"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "linesDo:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"linesDo:",{aBlock:aBlock},smalltalk.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: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "match:", category: 'regular expressions', fn: function (aRegexp){ var self=this; return smalltalk.withContext(function($ctx1) { return self.search(aRegexp) != -1; return self}, function($ctx1) {$ctx1.fill(self,"match:",{aRegexp:aRegexp},smalltalk.String)})}, args: ["aRegexp"], source: "match: aRegexp\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "matchesOf:", category: 'regular expressions', fn: function (aRegularExpression){ var self=this; return smalltalk.withContext(function($ctx1) { return self.match(aRegularExpression); return self}, function($ctx1) {$ctx1.fill(self,"matchesOf:",{aRegularExpression:aRegularExpression},smalltalk.String)})}, args: ["aRegularExpression"], source: "matchesOf: aRegularExpression\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "printNl", category: 'printing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { console.log(self); return self}, function($ctx1) {$ctx1.fill(self,"printNl",{},smalltalk.String)})}, args: [], source: "printNl\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aStream; _st($1)._nextPutAll_("'"); _st($1)._nextPutAll_(self); $2=_st($1)._nextPutAll_("'"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.String)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream \x0a\x09\x09nextPutAll: '''';\x0a\x09\x09nextPutAll: self;\x0a\x09\x09nextPutAll: ''''", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "replace:with:", category: 'regular expressions', fn: function (aString,anotherString){ var self=this; function $RegularExpression(){return smalltalk.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},smalltalk.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"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "replaceRegexp:with:", category: 'regular expressions', fn: function (aRegexp,aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.replace(aRegexp, aString); return self}, function($ctx1) {$ctx1.fill(self,"replaceRegexp:with:",{aRegexp:aRegexp,aString:aString},smalltalk.String)})}, args: ["aRegexp", "aString"], source: "replaceRegexp: aRegexp with: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "reversed", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.split("").reverse().join(""); return self}, function($ctx1) {$ctx1.fill(self,"reversed",{},smalltalk.String)})}, args: [], source: "reversed\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "shallowCopy", category: '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",{},smalltalk.String)})}, args: [], source: "shallowCopy\x0a\x09^self class fromString: self", messageSends: ["fromString:", "class"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.length; return self}, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.String)})}, args: [], source: "size\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "subStrings:", category: '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},smalltalk.String)})}, args: ["aString"], source: "subStrings: aString\x0a\x09^ self tokenize: aString", messageSends: ["tokenize:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "tokenize:", category: 'split join', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.split(aString); return self}, function($ctx1) {$ctx1.fill(self,"tokenize:",{aString:aString},smalltalk.String)})}, args: ["aString"], source: "tokenize: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimBoth", category: '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",{},smalltalk.String)})}, args: [], source: "trimBoth\x0a\x09^self trimBoth: '\x5cs'", messageSends: ["trimBoth:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimBoth:", category: '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},smalltalk.String)})}, args: ["separators"], source: "trimBoth: separators\x0a\x0a\x09^(self trimLeft: separators) trimRight: separators", messageSends: ["trimRight:", "trimLeft:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimLeft", category: '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",{},smalltalk.String)})}, args: [], source: "trimLeft\x0a\x09^self trimLeft: '\x5cs'", messageSends: ["trimLeft:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimLeft:", category: 'regular expressions', fn: function (separators){ var self=this; function $RegularExpression(){return smalltalk.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._replaceRegexp_with_(_st($RegularExpression())._fromString_flag_(_st("^[".__comma(separators)).__comma("]+"),"g"),""); return $1; }, function($ctx1) {$ctx1.fill(self,"trimLeft:",{separators:separators},smalltalk.String)})}, args: ["separators"], source: "trimLeft: separators\x0a\x0a\x09^self replaceRegexp: (RegularExpression fromString: '^[', separators, ']+' flag: 'g') with: ''", messageSends: ["replaceRegexp:with:", "fromString:flag:", ","], referencedClasses: ["RegularExpression"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimRight", category: '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",{},smalltalk.String)})}, args: [], source: "trimRight\x0a\x09^self trimRight: '\x5cs'", messageSends: ["trimRight:"], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "trimRight:", category: 'regular expressions', fn: function (separators){ var self=this; function $RegularExpression(){return smalltalk.RegularExpression||(typeof RegularExpression=="undefined"?nil:RegularExpression)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._replaceRegexp_with_(_st($RegularExpression())._fromString_flag_(_st("[".__comma(separators)).__comma("]+$"),"g"),""); return $1; }, function($ctx1) {$ctx1.fill(self,"trimRight:",{separators:separators},smalltalk.String)})}, args: ["separators"], source: "trimRight: separators\x0a\x0a\x09^self replaceRegexp: (RegularExpression fromString: '[', separators, ']+$' flag: 'g') with: ''", messageSends: ["replaceRegexp:with:", "fromString:flag:", ","], referencedClasses: ["RegularExpression"] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "unescaped", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return unescape(self); return self}, function($ctx1) {$ctx1.fill(self,"unescaped",{},smalltalk.String)})}, args: [], source: "unescaped\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "withIndexDo:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i=0;i", messageSends: [], referencedClasses: [] }), smalltalk.String); smalltalk.addMethod( smalltalk.method({ selector: "cr", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return '\r'; return self}, function($ctx1) {$ctx1.fill(self,"cr",{},smalltalk.String.klass)})}, args: [], source: "cr\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "crlf", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return '\r\n'; return self}, function($ctx1) {$ctx1.fill(self,"crlf",{},smalltalk.String.klass)})}, args: [], source: "crlf\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "esc", category: '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",{},smalltalk.String.klass)})}, args: [], source: "esc\x0a\x09^ self fromCharCode: 27", messageSends: ["fromCharCode:"], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromCharCode:", category: 'instance creation', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { return String.fromCharCode(anInteger); return self}, function($ctx1) {$ctx1.fill(self,"fromCharCode:",{anInteger:anInteger},smalltalk.String.klass)})}, args: ["anInteger"], source: "fromCharCode: anInteger\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromString:", category: 'instance creation', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return String(aString); return self}, function($ctx1) {$ctx1.fill(self,"fromString:",{aString:aString},smalltalk.String.klass)})}, args: ["aString"], source: "fromString: aString\x0a\x09\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "lf", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return '\n'; return self}, function($ctx1) {$ctx1.fill(self,"lf",{},smalltalk.String.klass)})}, args: [], source: "lf\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "random", category: 'random', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return (Math.random()*(22/32)+(10/32)).toString(32).slice(2);; return self}, function($ctx1) {$ctx1.fill(self,"random",{},smalltalk.String.klass)})}, args: [], source: "random\x0a\x09\x22Returns random alphanumeric string beginning with letter\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "randomNotIn:", category: '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)})}))._whileTrue(); $1=result; return $1; }, function($ctx1) {$ctx1.fill(self,"randomNotIn:",{aString:aString,result:result},smalltalk.String.klass)})}, args: ["aString"], source: "randomNotIn: aString\x0a\x09| result |\x0a [ result := self random. aString includesSubString: result ] whileTrue.\x0a ^result", messageSends: ["whileTrue", "random", "includesSubString:"], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "space", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return ' '; return self}, function($ctx1) {$ctx1.fill(self,"space",{},smalltalk.String.klass)})}, args: [], source: "space\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "streamClass", category: 'accessing', fn: function (){ var self=this; function $StringStream(){return smalltalk.StringStream||(typeof StringStream=="undefined"?nil:StringStream)} return smalltalk.withContext(function($ctx1) { var $1; $1=$StringStream(); return $1; }, function($ctx1) {$ctx1.fill(self,"streamClass",{},smalltalk.String.klass)})}, args: [], source: "streamClass\x0a\x09\x09^StringStream", messageSends: [], referencedClasses: ["StringStream"] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "tab", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return '\t'; return self}, function($ctx1) {$ctx1.fill(self,"tab",{},smalltalk.String.klass)})}, args: [], source: "tab\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'instance creation', fn: function (aUTFCharCode){ var self=this; return smalltalk.withContext(function($ctx1) { return String.fromCharCode(aUTFCharCode);; return self}, function($ctx1) {$ctx1.fill(self,"value:",{aUTFCharCode:aUTFCharCode},smalltalk.String.klass)})}, args: ["aUTFCharCode"], source: "value: aUTFCharCode\x0a\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.String.klass); smalltalk.addClass('Set', smalltalk.Collection, ['elements'], 'Kernel-Collections'); smalltalk.Set.comment="I represent an unordered set of objects without duplicates."; smalltalk.addMethod( smalltalk.method({ selector: "=", category: 'comparing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; var $early={}; try { $1=_st(self._class()).__eq(_st(aCollection)._class()); if(! smalltalk.assert($1)){ return false; }; $2=_st(self._size()).__eq(_st(aCollection)._size()); if(! smalltalk.assert($2)){ return false; }; self._do_((function(each){ return smalltalk.withContext(function($ctx2) { $3=_st(aCollection)._includes_(each); if(! smalltalk.assert($3)){ throw $early=[false]; }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return true; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"=",{aCollection:aCollection},smalltalk.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: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "add:", category: 'adding/removing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var found; for(var i=0; i < self['@elements'].length; i++) { if(_st(anObject).__eq(self['@elements'][i])) { found = true; break; } } if(!found) {self['@elements'].push(anObject)} ; return self}, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},smalltalk.Set)})}, args: ["anObject"], source: "add: anObject\x0a\x09<\x0a\x09\x09var found;\x0a\x09\x09for(var i=0; i < self['@elements'].length; i++) {\x0a\x09\x09\x09if(_st(anObject).__eq(self['@elements'][i])) {\x0a\x09\x09\x09\x09found = true;\x0a\x09\x09\x09\x09break;\x0a\x09\x09\x09}\x0a\x09\x09}\x0a\x09\x09if(!found) {self['@elements'].push(anObject)}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "asArray", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@elements"])._copy(); return $1; }, function($ctx1) {$ctx1.fill(self,"asArray",{},smalltalk.Set)})}, args: [], source: "asArray\x0a\x09^elements copy", messageSends: ["copy"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "collect:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._class())._withAll_(_st(self["@elements"])._collect_(aBlock)); return $1; }, function($ctx1) {$ctx1.fill(self,"collect:",{aBlock:aBlock},smalltalk.Set)})}, args: ["aBlock"], source: "collect: aBlock\x0a\x09^self class withAll: (elements collect: aBlock)", messageSends: ["withAll:", "collect:", "class"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "detect:ifNone:", category: 'enumerating', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@elements"])._detect_ifNone_(aBlock,anotherBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"detect:ifNone:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.Set)})}, args: ["aBlock", "anotherBlock"], source: "detect: aBlock ifNone: anotherBlock\x0a\x09^elements detect: aBlock ifNone: anotherBlock", messageSends: ["detect:ifNone:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@elements"])._do_(aBlock); return self}, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},smalltalk.Set)})}, args: ["aBlock"], source: "do: aBlock\x0a\x09elements do: aBlock", messageSends: ["do:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "includes:", category: 'testing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@elements"])._includes_(anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"includes:",{anObject:anObject},smalltalk.Set)})}, args: ["anObject"], source: "includes: anObject\x0a\x09^elements includes: anObject", messageSends: ["includes:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.Set.superclass.fn.prototype._initialize.apply(_st(self), []); self["@elements"]=[]; return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Set)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09elements := #()", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.Set.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); _st(aStream)._nextPutAll_(" ("); self._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._printOn_(aStream); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(aStream)._nextPutAll_(" "); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(aStream)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.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: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "remove:", category: 'adding/removing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@elements"])._remove_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"remove:",{anObject:anObject},smalltalk.Set)})}, args: ["anObject"], source: "remove: anObject\x0a\x09elements remove: anObject", messageSends: ["remove:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "remove:ifAbsent:", category: 'adding/removing', fn: function (anObject,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@elements"])._remove_ifAbsent_(anObject,aBlock); return self}, function($ctx1) {$ctx1.fill(self,"remove:ifAbsent:",{anObject:anObject,aBlock:aBlock},smalltalk.Set)})}, args: ["anObject", "aBlock"], source: "remove: anObject ifAbsent: aBlock\x0a\x09elements remove: anObject ifAbsent: aBlock", messageSends: ["remove:ifAbsent:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "select:", category: '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)})})); $2=collection; return $2; }, function($ctx1) {$ctx1.fill(self,"select:",{aBlock:aBlock,collection:collection},smalltalk.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:", "add:", "value:"], referencedClasses: [] }), smalltalk.Set); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@elements"])._size(); return $1; }, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.Set)})}, args: [], source: "size\x0a\x09^elements size", messageSends: ["size"], referencedClasses: [] }), smalltalk.Set); smalltalk.addClass('Queue', smalltalk.Object, ['read', 'readIndex', 'write'], 'Kernel-Collections'); smalltalk.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", category: 'initialization', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { smalltalk.Queue.superclass.fn.prototype._initialize.apply(_st(self), []); self["@read"]=_st($OrderedCollection())._new(); self["@write"]=_st($OrderedCollection())._new(); self["@readIndex"]=(1); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Queue)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09read := OrderedCollection new.\x0a\x09write := OrderedCollection new.\x0a\x09readIndex := 1", messageSends: ["initialize", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.Queue); smalltalk.addMethod( smalltalk.method({ selector: "next", category: '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)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"next",{},smalltalk.Queue)})}, args: [], source: "next\x0a\x09^self nextIfAbsent: [ self error: 'Cannot read from empty Queue.' ]", messageSends: ["nextIfAbsent:", "error:"], referencedClasses: [] }), smalltalk.Queue); smalltalk.addMethod( smalltalk.method({ selector: "nextIfAbsent:", category: 'accessing', fn: function (aBlock){ var self=this; var result; function $OrderedCollection(){return smalltalk.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)})})); _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},smalltalk.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:", ">", "value", "isEmpty", "new", "first", "at:put:", "+"], referencedClasses: ["OrderedCollection"] }), smalltalk.Queue); smalltalk.addMethod( smalltalk.method({ selector: "nextPut:", category: '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},smalltalk.Queue)})}, args: ["anObject"], source: "nextPut: anObject\x0a\x09write add: anObject", messageSends: ["add:"], referencedClasses: [] }), smalltalk.Queue); smalltalk.addClass('RegularExpression', smalltalk.Object, [], 'Kernel-Collections'); smalltalk.RegularExpression.comment="I represent a regular expression object. My instances are JavaScript `RegExp` object."; smalltalk.addMethod( smalltalk.method({ selector: "compile:", category: 'evaluating', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.compile(aString); return self}, function($ctx1) {$ctx1.fill(self,"compile:",{aString:aString},smalltalk.RegularExpression)})}, args: ["aString"], source: "compile: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.RegularExpression); smalltalk.addMethod( smalltalk.method({ selector: "exec:", category: 'evaluating', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.exec(aString) || nil; return self}, function($ctx1) {$ctx1.fill(self,"exec:",{aString:aString},smalltalk.RegularExpression)})}, args: ["aString"], source: "exec: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.RegularExpression); smalltalk.addMethod( smalltalk.method({ selector: "test:", category: 'evaluating', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self.test(aString); return self}, function($ctx1) {$ctx1.fill(self,"test:",{aString:aString},smalltalk.RegularExpression)})}, args: ["aString"], source: "test: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.RegularExpression); smalltalk.addMethod( smalltalk.method({ selector: "fromString:", category: '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},smalltalk.RegularExpression.klass)})}, args: ["aString"], source: "fromString: aString\x0a\x09\x09^self fromString: aString flag: ''", messageSends: ["fromString:flag:"], referencedClasses: [] }), smalltalk.RegularExpression.klass); smalltalk.addMethod( smalltalk.method({ selector: "fromString:flag:", category: 'instance creation', fn: function (aString,anotherString){ var self=this; return smalltalk.withContext(function($ctx1) { return new RegExp(aString, anotherString); return self}, function($ctx1) {$ctx1.fill(self,"fromString:flag:",{aString:aString,anotherString:anotherString},smalltalk.RegularExpression.klass)})}, args: ["aString", "anotherString"], source: "fromString: aString flag: anotherString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.RegularExpression.klass); smalltalk.addClass('Stream', smalltalk.Object, ['collection', 'position', 'streamSize'], 'Kernel-Collections'); smalltalk.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: "<<", category: 'writing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self._write_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"<<",{anObject:anObject},smalltalk.Stream)})}, args: ["anObject"], source: "<< anObject\x0a\x09self write: anObject", messageSends: ["write:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "atEnd", category: '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",{},smalltalk.Stream)})}, args: [], source: "atEnd\x0a\x09^self position = self size", messageSends: ["=", "size", "position"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "atStart", category: '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",{},smalltalk.Stream)})}, args: [], source: "atStart\x0a\x09^self position = 0", messageSends: ["=", "position"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "close", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"close",{},smalltalk.Stream)})}, args: [], source: "close", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "collection", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@collection"]; return $1; }, function($ctx1) {$ctx1.fill(self,"collection",{},smalltalk.Stream)})}, args: [], source: "collection\x0a\x09^collection", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "contents", category: '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",{},smalltalk.Stream)})}, args: [], source: "contents\x0a\x09^self collection\x0a\x09\x09copyFrom: 1\x0a\x09\x09to: self streamSize", messageSends: ["copyFrom:to:", "streamSize", "collection"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "do:", category: '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)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { return _st(aBlock)._value_(self._next()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"do:",{aBlock:aBlock},smalltalk.Stream)})}, args: ["aBlock"], source: "do: aBlock\x0a\x09[self atEnd] whileFalse: [aBlock value: self next]", messageSends: ["whileFalse:", "value:", "next", "atEnd"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "flush", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"flush",{},smalltalk.Stream)})}, args: [], source: "flush", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "isEmpty", category: '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",{},smalltalk.Stream)})}, args: [], source: "isEmpty\x0a\x09^self size = 0", messageSends: ["=", "size"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "next", category: 'reading', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._atEnd(); if(smalltalk.assert($2)){ $1=nil; } else { self._position_(_st(self._position()).__plus((1))); $1=_st(self["@collection"])._at_(self._position()); }; return $1; }, function($ctx1) {$ctx1.fill(self,"next",{},smalltalk.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:", "position:", "+", "position", "at:", "atEnd"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "next:", category: '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)})})); $2=tempCollection; return $2; }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger,tempCollection:tempCollection},smalltalk.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:", "add:", "next", "atEnd"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "nextPut:", category: 'writing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self._position_(_st(self._position()).__plus((1))); _st(self._collection())._at_put_(self._position(),anObject); self._setStreamSize_(_st(self._streamSize())._max_(self._position())); return self}, function($ctx1) {$ctx1.fill(self,"nextPut:",{anObject:anObject},smalltalk.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: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutAll:", category: '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)})})); return self}, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aCollection:aCollection},smalltalk.Stream)})}, args: ["aCollection"], source: "nextPutAll: aCollection\x0a\x09aCollection do: [:each |\x0a\x09\x09self nextPut: each]", messageSends: ["do:", "nextPut:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutString:", category: '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},smalltalk.Stream)})}, args: ["aString"], source: "nextPutString: aString\x0a\x09self nextPut: aString", messageSends: ["nextPut:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "peek", category: '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",{},smalltalk.Stream)})}, args: [], source: "peek\x0a\x09^self atEnd ifFalse: [\x0a\x09\x09self collection at: self position + 1]", messageSends: ["ifFalse:", "at:", "+", "position", "collection", "atEnd"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "position", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@position"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@position"]=(0); $1=self["@position"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"position",{},smalltalk.Stream)})}, args: [], source: "position\x0a\x09^position ifNil: [position := 0]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "position:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@position"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"position:",{anInteger:anInteger},smalltalk.Stream)})}, args: ["anInteger"], source: "position: anInteger\x0a\x09position := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "reset", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._position_((0)); return self}, function($ctx1) {$ctx1.fill(self,"reset",{},smalltalk.Stream)})}, args: [], source: "reset\x0a\x09self position: 0", messageSends: ["position:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "resetContents", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._reset(); self._setStreamSize_((0)); return self}, function($ctx1) {$ctx1.fill(self,"resetContents",{},smalltalk.Stream)})}, args: [], source: "resetContents\x0a\x09self reset.\x0a\x09self setStreamSize: 0", messageSends: ["reset", "setStreamSize:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "setCollection:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@collection"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"setCollection:",{aCollection:aCollection},smalltalk.Stream)})}, args: ["aCollection"], source: "setCollection: aCollection\x0a\x09collection := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "setStreamSize:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@streamSize"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"setStreamSize:",{anInteger:anInteger},smalltalk.Stream)})}, args: ["anInteger"], source: "setStreamSize: anInteger\x0a\x09streamSize := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "setToEnd", category: 'positioning', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._position_(self._size()); return self}, function($ctx1) {$ctx1.fill(self,"setToEnd",{},smalltalk.Stream)})}, args: [], source: "setToEnd\x0a\x09self position: self size", messageSends: ["position:", "size"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "size", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._streamSize(); return $1; }, function($ctx1) {$ctx1.fill(self,"size",{},smalltalk.Stream)})}, args: [], source: "size\x0a\x09^self streamSize", messageSends: ["streamSize"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "skip:", category: '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},smalltalk.Stream)})}, args: ["anInteger"], source: "skip: anInteger\x0a\x09self position: ((self position + anInteger) min: self size max: 0)", messageSends: ["position:", "min:max:", "size", "+", "position"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "streamSize", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@streamSize"]; return $1; }, function($ctx1) {$ctx1.fill(self,"streamSize",{},smalltalk.Stream)})}, args: [], source: "streamSize\x0a\x09^streamSize", messageSends: [], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "write:", category: '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},smalltalk.Stream)})}, args: ["anObject"], source: "write: anObject\x0a\x09anObject putOn: self", messageSends: ["putOn:"], referencedClasses: [] }), smalltalk.Stream); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: '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},smalltalk.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: [] }), smalltalk.Stream.klass); smalltalk.addClass('StringStream', smalltalk.Stream, [], 'Kernel-Collections'); smalltalk.StringStream.comment="I am a Stream specific to `String` objects."; smalltalk.addMethod( smalltalk.method({ selector: "cr", category: 'writing', fn: function (){ var self=this; function $String(){return smalltalk.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",{},smalltalk.StringStream)})}, args: [], source: "cr\x0a\x09^self nextPutAll: String cr", messageSends: ["nextPutAll:", "cr"], referencedClasses: ["String"] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "crlf", category: 'writing', fn: function (){ var self=this; function $String(){return smalltalk.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",{},smalltalk.StringStream)})}, args: [], source: "crlf\x0a\x09^self nextPutAll: String crlf", messageSends: ["nextPutAll:", "crlf"], referencedClasses: ["String"] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "lf", category: 'writing', fn: function (){ var self=this; function $String(){return smalltalk.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",{},smalltalk.StringStream)})}, args: [], source: "lf\x0a\x09^self nextPutAll: String lf", messageSends: ["nextPutAll:", "lf"], referencedClasses: ["String"] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "next:", category: '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)})})); $2=tempCollection; return $2; }, function($ctx1) {$ctx1.fill(self,"next:",{anInteger:anInteger,tempCollection:tempCollection},smalltalk.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:", ",", "next", "atEnd"], referencedClasses: [] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPut:", category: '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},smalltalk.StringStream)})}, args: ["aString"], source: "nextPut: aString\x0a\x09self nextPutAll: aString", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutAll:", category: 'writing', fn: function (aString){ var self=this; var pre,post; return smalltalk.withContext(function($ctx1) { var $1; $1=self._atEnd(); if(smalltalk.assert($1)){ self._setCollection_(_st(self._collection()).__comma(aString)); } else { pre=_st(self._collection())._copyFrom_to_((1),self._position()); pre; post=_st(self._collection())._copyFrom_to_(_st(_st(self._position()).__plus((1))).__plus(_st(aString)._size()),_st(self._collection())._size()); post; self._setCollection_(_st(_st(pre).__comma(aString)).__comma(post)); }; self._position_(_st(self._position()).__plus(_st(aString)._size())); self._setStreamSize_(_st(self._streamSize())._max_(self._position())); return self}, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aString:aString,pre:pre,post:post},smalltalk.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:", "setCollection:", ",", "collection", "copyFrom:to:", "position", "+", "size", "atEnd", "position:", "setStreamSize:", "max:", "streamSize"], referencedClasses: [] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutString:", category: '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},smalltalk.StringStream)})}, args: ["aString"], source: "nextPutString: aString\x0a\x09self nextPutAll: aString", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "space", category: 'writing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._nextPut_(" "); return self}, function($ctx1) {$ctx1.fill(self,"space",{},smalltalk.StringStream)})}, args: [], source: "space\x0a\x09self nextPut: ' '", messageSends: ["nextPut:"], referencedClasses: [] }), smalltalk.StringStream); smalltalk.addMethod( smalltalk.method({ selector: "tab", category: 'writing', fn: function (){ var self=this; function $String(){return smalltalk.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",{},smalltalk.StringStream)})}, args: [], source: "tab\x0a\x09^self nextPutAll: String tab", messageSends: ["nextPutAll:", "tab"], referencedClasses: ["String"] }), smalltalk.StringStream); }); define("amber_core/Kernel-Infrastructure", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects", "amber_core/Kernel-Collections"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Infrastructure'); smalltalk.packages["Kernel-Infrastructure"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('InspectorHandler', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.InspectorHandler.comment="I am responsible for inspecting object.\x0a\x0aMy class-side `inspector` inst var holds the current inspector I'm delegating object inspection to.\x0a\x0aThe default inspector object is the transcript."; smalltalk.InspectorHandler.klass.iVarNames = ['inspector']; smalltalk.addMethod( smalltalk.method({ selector: "inspect:", category: 'registration', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._inspector())._inspect_(anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},smalltalk.InspectorHandler.klass)})}, args: ["anObject"], source: "inspect: anObject\x0a\x09^ self inspector inspect: anObject", messageSends: ["inspect:", "inspector"], referencedClasses: [] }), smalltalk.InspectorHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "inspector", category: 'accessing', fn: function (){ var self=this; function $Transcript(){return smalltalk.Transcript||(typeof Transcript=="undefined"?nil:Transcript)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@inspector"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@inspector"]=$Transcript(); $1=self["@inspector"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"inspector",{},smalltalk.InspectorHandler.klass)})}, args: [], source: "inspector\x0a\x09^ inspector ifNil: [ inspector := Transcript ]", messageSends: ["ifNil:"], referencedClasses: ["Transcript"] }), smalltalk.InspectorHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "register:", category: 'registration', fn: function (anInspector){ var self=this; return smalltalk.withContext(function($ctx1) { self["@inspector"]=anInspector; return self}, function($ctx1) {$ctx1.fill(self,"register:",{anInspector:anInspector},smalltalk.InspectorHandler.klass)})}, args: ["anInspector"], source: "register: anInspector\x0a\x09inspector := anInspector", messageSends: [], referencedClasses: [] }), smalltalk.InspectorHandler.klass); smalltalk.addClass('InterfacingObject', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.InterfacingObject.comment="I am superclass of all object that interface with user or environment. `Widget` and a few other classes are subclasses of me. I delegate all of the above APIs to `PlatformInterface`.\x0a\x0a## API\x0a\x0a self alert: 'Hey, there is a problem'.\x0a self confirm: 'Affirmative?'.\x0a self prompt: 'Your name:'.\x0a\x0a self ajax: #{\x0a 'url' -> '/patch.js'. 'type' -> 'GET'. dataType->'script'\x0a }."; smalltalk.addMethod( smalltalk.method({ selector: "ajax:", category: 'actions', fn: function (anObject){ var self=this; function $PlatformInterface(){return smalltalk.PlatformInterface||(typeof PlatformInterface=="undefined"?nil:PlatformInterface)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($PlatformInterface())._ajax_(anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"ajax:",{anObject:anObject},smalltalk.InterfacingObject)})}, args: ["anObject"], source: "ajax: anObject\x0a\x09^PlatformInterface ajax: anObject", messageSends: ["ajax:"], referencedClasses: ["PlatformInterface"] }), smalltalk.InterfacingObject); smalltalk.addMethod( smalltalk.method({ selector: "alert:", category: 'actions', fn: function (aString){ var self=this; function $PlatformInterface(){return smalltalk.PlatformInterface||(typeof PlatformInterface=="undefined"?nil:PlatformInterface)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($PlatformInterface())._alert_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"alert:",{aString:aString},smalltalk.InterfacingObject)})}, args: ["aString"], source: "alert: aString\x0a\x09^PlatformInterface alert: aString", messageSends: ["alert:"], referencedClasses: ["PlatformInterface"] }), smalltalk.InterfacingObject); smalltalk.addMethod( smalltalk.method({ selector: "confirm:", category: 'actions', fn: function (aString){ var self=this; function $PlatformInterface(){return smalltalk.PlatformInterface||(typeof PlatformInterface=="undefined"?nil:PlatformInterface)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($PlatformInterface())._confirm_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"confirm:",{aString:aString},smalltalk.InterfacingObject)})}, args: ["aString"], source: "confirm: aString\x0a\x09^PlatformInterface confirm: aString", messageSends: ["confirm:"], referencedClasses: ["PlatformInterface"] }), smalltalk.InterfacingObject); smalltalk.addMethod( smalltalk.method({ selector: "prompt:", category: 'actions', fn: function (aString){ var self=this; function $PlatformInterface(){return smalltalk.PlatformInterface||(typeof PlatformInterface=="undefined"?nil:PlatformInterface)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($PlatformInterface())._prompt_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"prompt:",{aString:aString},smalltalk.InterfacingObject)})}, args: ["aString"], source: "prompt: aString\x0a\x09^PlatformInterface prompt: aString", messageSends: ["prompt:"], referencedClasses: ["PlatformInterface"] }), smalltalk.InterfacingObject); smalltalk.addClass('Environment', smalltalk.InterfacingObject, [], 'Kernel-Infrastructure'); smalltalk.Environment.comment="I provide an unified entry point to manipulate Amber packages, classes and methods.\x0a\x0aTypical use cases include IDEs, remote access and restricting browsing."; smalltalk.addMethod( smalltalk.method({ selector: "addInstVarNamed:to:", category: 'compiling', fn: function (aString,aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(_st(aClass)._instanceVariableNames())._copy(); _st($1)._add_(aString); $2=_st($1)._yourself(); _st(self._classBuilder())._addSubclassOf_named_instanceVariableNames_package_(_st(aClass)._superclass(),_st(aClass)._name(),$2,_st(_st(aClass)._package())._name()); return self}, function($ctx1) {$ctx1.fill(self,"addInstVarNamed:to:",{aString:aString,aClass:aClass},smalltalk.Environment)})}, args: ["aString", "aClass"], source: "addInstVarNamed: aString to: aClass\x0a\x09self classBuilder\x0a\x09\x09addSubclassOf: aClass superclass \x0a\x09\x09named: aClass name \x0a\x09\x09instanceVariableNames: (aClass instanceVariableNames copy add: aString; yourself)\x0a\x09\x09package: aClass package name", messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "superclass", "name", "add:", "copy", "instanceVariableNames", "yourself", "package", "classBuilder"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "allSelectors", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st($Smalltalk())._current())._at_("allSelectors"))._value(); return $1; }, function($ctx1) {$ctx1.fill(self,"allSelectors",{},smalltalk.Environment)})}, args: [], source: "allSelectors\x0a\x09^ (Smalltalk current at: 'allSelectors') value", messageSends: ["value", "at:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "availableClassNames", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st($Smalltalk())._current())._classes())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._name(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"availableClassNames",{},smalltalk.Environment)})}, args: [], source: "availableClassNames\x0a\x09^ Smalltalk current classes \x0a\x09\x09collect: [ :each | each name ]", messageSends: ["collect:", "name", "classes", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "availablePackageNames", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st($Smalltalk())._current())._packages())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._name(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"availablePackageNames",{},smalltalk.Environment)})}, args: [], source: "availablePackageNames\x0a\x09^ Smalltalk current packages \x0a\x09\x09collect: [ :each | each name ]", messageSends: ["collect:", "name", "packages", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "availableProtocolsFor:", category: 'accessing', fn: function (aClass){ var self=this; var protocols; return smalltalk.withContext(function($ctx1) { var $1,$2; protocols=_st(aClass)._protocols(); $1=_st(aClass)._superclass(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { _st(protocols)._addAll_(self._availableProtocolsFor_(_st(aClass)._superclass())); }; $2=_st(_st(protocols)._asSet())._asArray(); return $2; }, function($ctx1) {$ctx1.fill(self,"availableProtocolsFor:",{aClass:aClass,protocols:protocols},smalltalk.Environment)})}, args: ["aClass"], source: "availableProtocolsFor: aClass\x0a\x09| protocols |\x0a\x09\x0a\x09protocols := aClass protocols.\x0a\x09aClass superclass ifNotNil: [ protocols addAll: (self availableProtocolsFor: aClass superclass) ].\x0a\x09^ protocols asSet asArray", messageSends: ["protocols", "ifNotNil:", "addAll:", "availableProtocolsFor:", "superclass", "asArray", "asSet"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "classBuilder", category: 'accessing', fn: function (){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($ClassBuilder())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"classBuilder",{},smalltalk.Environment)})}, args: [], source: "classBuilder\x0a\x09^ ClassBuilder new", messageSends: ["new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "classNamed:", category: 'accessing', fn: function (aString){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st($Smalltalk())._current())._at_(_st(aString)._asSymbol()); if(($receiver = $2) == nil || $receiver == undefined){ $1=self._error_("Invalid class name"); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"classNamed:",{aString:aString},smalltalk.Environment)})}, args: ["aString"], source: "classNamed: aString\x0a\x09^ (Smalltalk current at: aString asSymbol)\x0a\x09\x09ifNil: [ self error: 'Invalid class name' ]", messageSends: ["ifNil:", "error:", "at:", "asSymbol", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "classes", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._classes(); return $1; }, function($ctx1) {$ctx1.fill(self,"classes",{},smalltalk.Environment)})}, args: [], source: "classes\x0a\x09^ Smalltalk current classes", messageSends: ["classes", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "commitPackage:", category: 'actions', fn: function (aPackage){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aPackage)._commit(); return self}, function($ctx1) {$ctx1.fill(self,"commitPackage:",{aPackage:aPackage},smalltalk.Environment)})}, args: ["aPackage"], source: "commitPackage: aPackage\x0a\x09aPackage commit", messageSends: ["commit"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "compileClassComment:for:", category: 'compiling', fn: function (aString,aClass){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aClass)._comment_(aString); return self}, function($ctx1) {$ctx1.fill(self,"compileClassComment:for:",{aString:aString,aClass:aClass},smalltalk.Environment)})}, args: ["aString", "aClass"], source: "compileClassComment: aString for: aClass\x0a\x09aClass comment: aString", messageSends: ["comment:"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "compileClassDefinition:", category: 'compiling', fn: function (aString){ var self=this; function $DoIt(){return smalltalk.DoIt||(typeof DoIt=="undefined"?nil:DoIt)} return smalltalk.withContext(function($ctx1) { self._eval_on_(aString,_st($DoIt())._new()); return self}, function($ctx1) {$ctx1.fill(self,"compileClassDefinition:",{aString:aString},smalltalk.Environment)})}, args: ["aString"], source: "compileClassDefinition: aString\x0a\x09self eval: aString on: DoIt new", messageSends: ["eval:on:", "new"], referencedClasses: ["DoIt"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "compileMethod:for:protocol:", category: 'compiling', fn: function (sourceCode,class_,protocol){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(class_)._compile_category_(sourceCode,protocol); return $1; }, function($ctx1) {$ctx1.fill(self,"compileMethod:for:protocol:",{sourceCode:sourceCode,class_:class_,protocol:protocol},smalltalk.Environment)})}, args: ["sourceCode", "class", "protocol"], source: "compileMethod: sourceCode for: class protocol: protocol\x0a\x09^ class\x0a\x09\x09compile: sourceCode\x0a\x09\x09category: protocol", messageSends: ["compile:category:"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "copyClass:to:", category: 'actions', fn: function (aClass,aClassName){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._at_(aClassName); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._error_(_st("A class named ".__comma(aClassName)).__comma(" already exists")); }; _st(_st($ClassBuilder())._new())._copyClass_named_(aClass,aClassName); return self}, function($ctx1) {$ctx1.fill(self,"copyClass:to:",{aClass:aClass,aClassName:aClassName},smalltalk.Environment)})}, args: ["aClass", "aClassName"], source: "copyClass: aClass to: aClassName\x0a\x09(Smalltalk current at: aClassName)\x0a\x09\x09ifNotNil: [ self error: 'A class named ', aClassName, ' already exists' ].\x0a\x09\x09\x0a\x09ClassBuilder new copyClass: aClass named: aClassName", messageSends: ["ifNotNil:", "error:", ",", "at:", "current", "copyClass:named:", "new"], referencedClasses: ["Smalltalk", "ClassBuilder"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "eval:on:", category: 'actions', fn: function (aString,aReceiver){ var self=this; var compiler; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} function $Error(){return smalltalk.Error||(typeof Error=="undefined"?nil:Error)} return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { compiler=_st($Compiler())._new(); _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(compiler)._parseExpression_(aString); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._on_do_($Error(),(function(ex){ return smalltalk.withContext(function($ctx2) { $1=self._alert_(_st(ex)._messageText()); throw $early=[$1]; }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1)})})); $2=_st(compiler)._evaluateExpression_on_(aString,aReceiver); return $2; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"eval:on:",{aString:aString,aReceiver:aReceiver,compiler:compiler},smalltalk.Environment)})}, args: ["aString", "aReceiver"], source: "eval: aString on: aReceiver\x0a\x09| compiler |\x0a\x09compiler := Compiler new.\x0a\x09[ compiler parseExpression: aString ] on: Error do: [ :ex |\x0a\x09\x09^ self alert: ex messageText ].\x0a\x09^ compiler evaluateExpression: aString on: aReceiver", messageSends: ["new", "on:do:", "alert:", "messageText", "parseExpression:", "evaluateExpression:on:"], referencedClasses: ["Compiler", "Error"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "evaluate:on:do:", category: 'error handling', fn: function (aBlock,anErrorClass,exceptionBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._try_catch_(aBlock,(function(exception){ return smalltalk.withContext(function($ctx2) { $1=_st(exception)._isKindOf_(self._classNamed_(_st(anErrorClass)._name())); if(smalltalk.assert($1)){ return _st(exceptionBlock)._value_(exception); } else { return _st(exception)._signal(); }; }, function($ctx2) {$ctx2.fillBlock({exception:exception},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"evaluate:on:do:",{aBlock:aBlock,anErrorClass:anErrorClass,exceptionBlock:exceptionBlock},smalltalk.Environment)})}, args: ["aBlock", "anErrorClass", "exceptionBlock"], source: "evaluate: aBlock on: anErrorClass do: exceptionBlock\x0a\x09\x22Evaluate a block and catch exceptions happening on the environment stack\x22\x0a\x09\x0a\x09self try: aBlock catch: [ :exception | \x0a\x09\x09(exception isKindOf: (self classNamed: anErrorClass name))\x0a\x09\x09\x09ifTrue: [ exceptionBlock value: exception ]\x0a \x09\x09\x09ifFalse: [ exception signal ] ]", messageSends: ["try:catch:", "ifTrue:ifFalse:", "value:", "signal", "isKindOf:", "classNamed:", "name"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "inspect:", category: 'actions', fn: function (anObject){ var self=this; function $InspectorHandler(){return smalltalk.InspectorHandler||(typeof InspectorHandler=="undefined"?nil:InspectorHandler)} return smalltalk.withContext(function($ctx1) { _st(_st($InspectorHandler())._inspector())._inspect_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},smalltalk.Environment)})}, args: ["anObject"], source: "inspect: anObject\x0a\x09InspectorHandler inspector inspect: anObject", messageSends: ["inspect:", "inspector"], referencedClasses: ["InspectorHandler"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "moveClass:toPackage:", category: 'actions', fn: function (aClass,aPackageName){ var self=this; var package_; function $Package(){return smalltalk.Package||(typeof Package=="undefined"?nil:Package)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; package_=_st($Package())._named_(aPackageName); $1=package_; if(($receiver = $1) == nil || $receiver == undefined){ self._error_("Invalid package name"); } else { $1; }; $2=_st(package_).__eq_eq(_st(aClass)._package()); if(smalltalk.assert($2)){ $3=self; return $3; }; _st(aClass)._package_(package_); return self}, function($ctx1) {$ctx1.fill(self,"moveClass:toPackage:",{aClass:aClass,aPackageName:aPackageName,package_:package_},smalltalk.Environment)})}, args: ["aClass", "aPackageName"], source: "moveClass: aClass toPackage: aPackageName\x0a\x09| package |\x0a\x09\x0a\x09package := Package named: aPackageName.\x0a\x09package ifNil: [ self error: 'Invalid package name' ].\x0a\x09package == aClass package ifTrue: [ ^ self ].\x0a\x09\x0a\x09aClass package: package", messageSends: ["named:", "ifNil:", "error:", "ifTrue:", "==", "package", "package:"], referencedClasses: ["Package"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "moveMethod:toClass:", category: 'actions', fn: function (aMethod,aClassName){ var self=this; var destinationClass; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; destinationClass=_st(_st($Smalltalk())._current())._at_(_st(aClassName)._asSymbol()); $1=destinationClass; if(($receiver = $1) == nil || $receiver == undefined){ self._error_("Invalid class name"); } else { $1; }; $2=_st(destinationClass).__eq_eq(_st(aMethod)._methodClass()); if(smalltalk.assert($2)){ $3=self; return $3; }; _st(destinationClass)._compile_category_(_st(aMethod)._source(),_st(aMethod)._protocol()); _st(_st(aMethod)._methodClass())._removeCompiledMethod_(aMethod); return self}, function($ctx1) {$ctx1.fill(self,"moveMethod:toClass:",{aMethod:aMethod,aClassName:aClassName,destinationClass:destinationClass},smalltalk.Environment)})}, args: ["aMethod", "aClassName"], source: "moveMethod: aMethod toClass: aClassName\x0a\x09| destinationClass |\x0a\x09\x0a\x09destinationClass := Smalltalk current at: aClassName asSymbol.\x0a\x09destinationClass ifNil: [ self error: 'Invalid class name' ].\x0a\x09destinationClass == aMethod methodClass ifTrue: [ ^ self ].\x0a\x09\x0a\x09destinationClass \x0a\x09\x09compile: aMethod source\x0a\x09\x09category: aMethod protocol.\x0a\x09aMethod methodClass \x0a\x09\x09removeCompiledMethod: aMethod", messageSends: ["at:", "asSymbol", "current", "ifNil:", "error:", "ifTrue:", "==", "methodClass", "compile:category:", "source", "protocol", "removeCompiledMethod:"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "moveMethod:toProtocol:", category: 'actions', fn: function (aMethod,aProtocol){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aMethod)._category_(aProtocol); return self}, function($ctx1) {$ctx1.fill(self,"moveMethod:toProtocol:",{aMethod:aMethod,aProtocol:aProtocol},smalltalk.Environment)})}, args: ["aMethod", "aProtocol"], source: "moveMethod: aMethod toProtocol: aProtocol\x0a\x09aMethod category: aProtocol", messageSends: ["category:"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "packages", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._packages(); return $1; }, function($ctx1) {$ctx1.fill(self,"packages",{},smalltalk.Environment)})}, args: [], source: "packages\x0a\x09^ Smalltalk current packages", messageSends: ["packages", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "registerErrorHandler:", category: 'actions', fn: function (anErrorHandler){ var self=this; function $ErrorHandler(){return smalltalk.ErrorHandler||(typeof ErrorHandler=="undefined"?nil:ErrorHandler)} return smalltalk.withContext(function($ctx1) { _st($ErrorHandler())._setCurrent_(anErrorHandler); return self}, function($ctx1) {$ctx1.fill(self,"registerErrorHandler:",{anErrorHandler:anErrorHandler},smalltalk.Environment)})}, args: ["anErrorHandler"], source: "registerErrorHandler: anErrorHandler\x0a\x09ErrorHandler setCurrent: anErrorHandler", messageSends: ["setCurrent:"], referencedClasses: ["ErrorHandler"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "registerInspector:", category: 'actions', fn: function (anInspector){ var self=this; function $InspectorHandler(){return smalltalk.InspectorHandler||(typeof InspectorHandler=="undefined"?nil:InspectorHandler)} return smalltalk.withContext(function($ctx1) { _st($InspectorHandler())._register_(anInspector); return self}, function($ctx1) {$ctx1.fill(self,"registerInspector:",{anInspector:anInspector},smalltalk.Environment)})}, args: ["anInspector"], source: "registerInspector: anInspector\x0a\x09InspectorHandler register: anInspector", messageSends: ["register:"], referencedClasses: ["InspectorHandler"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "registerProgressHandler:", category: 'actions', fn: function (aProgressHandler){ var self=this; function $ProgressHandler(){return smalltalk.ProgressHandler||(typeof ProgressHandler=="undefined"?nil:ProgressHandler)} return smalltalk.withContext(function($ctx1) { _st($ProgressHandler())._setCurrent_(aProgressHandler); return self}, function($ctx1) {$ctx1.fill(self,"registerProgressHandler:",{aProgressHandler:aProgressHandler},smalltalk.Environment)})}, args: ["aProgressHandler"], source: "registerProgressHandler: aProgressHandler\x0a\x09ProgressHandler setCurrent: aProgressHandler", messageSends: ["setCurrent:"], referencedClasses: ["ProgressHandler"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "removeClass:", category: 'actions', fn: function (aClass){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { _st(_st($Smalltalk())._current())._removeClass_(aClass); return self}, function($ctx1) {$ctx1.fill(self,"removeClass:",{aClass:aClass},smalltalk.Environment)})}, args: ["aClass"], source: "removeClass: aClass\x0a\x09Smalltalk current removeClass: aClass", messageSends: ["removeClass:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "removeMethod:", category: 'actions', fn: function (aMethod){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(aMethod)._methodClass())._removeCompiledMethod_(aMethod); return self}, function($ctx1) {$ctx1.fill(self,"removeMethod:",{aMethod:aMethod},smalltalk.Environment)})}, args: ["aMethod"], source: "removeMethod: aMethod\x0a\x09aMethod methodClass removeCompiledMethod: aMethod", messageSends: ["removeCompiledMethod:", "methodClass"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "removeProtocol:from:", category: 'actions', fn: function (aString,aClass){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(_st(aClass)._methods())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocol()).__eq(aString); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(aClass)._removeCompiledMethod_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"removeProtocol:from:",{aString:aString,aClass:aClass},smalltalk.Environment)})}, args: ["aString", "aClass"], source: "removeProtocol: aString from: aClass\x0a\x09(aClass methods\x0a\x09\x09select: [ :each | each protocol = aString ])\x0a\x09\x09do: [ :each | aClass removeCompiledMethod: each ]", messageSends: ["do:", "removeCompiledMethod:", "select:", "=", "protocol", "methods"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "renameClass:to:", category: 'actions', fn: function (aClass,aClassName){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._at_(aClassName); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._error_(_st("A class named ".__comma(aClassName)).__comma(" already exists")); }; _st(_st($ClassBuilder())._new())._renameClass_to_(aClass,aClassName); return self}, function($ctx1) {$ctx1.fill(self,"renameClass:to:",{aClass:aClass,aClassName:aClassName},smalltalk.Environment)})}, args: ["aClass", "aClassName"], source: "renameClass: aClass to: aClassName\x0a\x09(Smalltalk current at: aClassName)\x0a\x09\x09ifNotNil: [ self error: 'A class named ', aClassName, ' already exists' ].\x0a\x09\x09\x0a\x09ClassBuilder new renameClass: aClass to: aClassName", messageSends: ["ifNotNil:", "error:", ",", "at:", "current", "renameClass:to:", "new"], referencedClasses: ["Smalltalk", "ClassBuilder"] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "renameProtocol:to:in:", category: 'actions', fn: function (aString,anotherString,aClass){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(_st(aClass)._methods())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocol()).__eq(aString); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._protocol_(anotherString); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"renameProtocol:to:in:",{aString:aString,anotherString:anotherString,aClass:aClass},smalltalk.Environment)})}, args: ["aString", "anotherString", "aClass"], source: "renameProtocol: aString to: anotherString in: aClass\x0a\x09(aClass methods\x0a\x09\x09select: [ :each | each protocol = aString ])\x0a\x09\x09do: [ :each | each protocol: anotherString ]", messageSends: ["do:", "protocol:", "select:", "=", "protocol", "methods"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "setClassCommentOf:to:", category: 'actions', fn: function (aClass,aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aClass)._comment_(aString); return self}, function($ctx1) {$ctx1.fill(self,"setClassCommentOf:to:",{aClass:aClass,aString:aString},smalltalk.Environment)})}, args: ["aClass", "aString"], source: "setClassCommentOf: aClass to: aString\x0a\x09aClass comment: aString", messageSends: ["comment:"], referencedClasses: [] }), smalltalk.Environment); smalltalk.addMethod( smalltalk.method({ selector: "systemAnnouncer", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st($Smalltalk())._current())._at_("SystemAnnouncer"))._current(); return $1; }, function($ctx1) {$ctx1.fill(self,"systemAnnouncer",{},smalltalk.Environment)})}, args: [], source: "systemAnnouncer\x0a\x09^ (Smalltalk current at: #SystemAnnouncer) current", messageSends: ["current", "at:"], referencedClasses: ["Smalltalk"] }), smalltalk.Environment); smalltalk.addClass('JSObjectProxy', smalltalk.Object, ['jsObject'], 'Kernel-Infrastructure'); smalltalk.JSObjectProxy.comment="I handle sending messages to JavaScript objects, making JavaScript object accessing from Amber fully transparent.\x0aMy instances make intensive use of `#doesNotUnderstand:`.\x0a\x0aMy instances are automatically created by Amber whenever a message is sent to a JavaScript object.\x0a\x0a## Usage examples\x0a\x0aJSObjectProxy objects are instanciated by Amber when a Smalltalk message is sent to a JavaScript object.\x0a\x0a\x09window alert: 'hello world'.\x0a\x09window inspect.\x0a\x09(window jQuery: 'body') append: 'hello world'\x0a\x0aAmber messages sends are converted to JavaScript function calls or object property access _(in this order)_. If n one of them match, a `MessageNotUnderstood` error will be thrown.\x0a\x0a## Message conversion rules\x0a\x0a- `someUser name` becomes `someUser.name`\x0a- `someUser name: 'John'` becomes `someUser name = \x22John\x22`\x0a- `console log: 'hello world'` becomes `console.log('hello world')`\x0a- `(window jQuery: 'foo') css: 'background' color: 'red'` becomes `window.jQuery('foo').css('background', 'red')`\x0a\x0a__Note:__ For keyword-based messages, only the first keyword is kept: `window foo: 1 bar: 2` is equivalent to `window foo: 1 baz: 2`."; smalltalk.addMethod( smalltalk.method({ selector: "addObjectVariablesTo:", category: 'proxy', fn: function (aDictionary){ var self=this; return smalltalk.withContext(function($ctx1) { for(var i in self['@jsObject']) { aDictionary._at_put_(i, self['@jsObject'][i]); } ; return self}, function($ctx1) {$ctx1.fill(self,"addObjectVariablesTo:",{aDictionary:aDictionary},smalltalk.JSObjectProxy)})}, args: ["aDictionary"], source: "addObjectVariablesTo: aDictionary\x0a\x09<\x0a\x09\x09for(var i in self['@jsObject']) {\x0a\x09\x09\x09aDictionary._at_put_(i, self['@jsObject'][i]);\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "at:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return self['@jsObject'][aString]; return self}, function($ctx1) {$ctx1.fill(self,"at:",{aString:aString},smalltalk.JSObjectProxy)})}, args: ["aString"], source: "at: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "at:ifAbsent:", category: 'accessing', fn: function (aString,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var obj = self['@jsObject']; return aString in obj ? obj[aString] : aBlock._value(); ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifAbsent:",{aString:aString,aBlock:aBlock},smalltalk.JSObjectProxy)})}, args: ["aString", "aBlock"], source: "at: aString ifAbsent: aBlock\x0a\x09\x22return the aString property or evaluate aBlock if the property is not defined on the object\x22\x0a\x09<\x0a\x09\x09var obj = self['@jsObject'];\x0a\x09\x09return aString in obj ? obj[aString] : aBlock._value();\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:", category: 'accessing', fn: function (aString,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var obj = self['@jsObject']; return aString in obj ? aBlock._value_(obj[aString]) : nil; ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifPresent:",{aString:aString,aBlock:aBlock},smalltalk.JSObjectProxy)})}, args: ["aString", "aBlock"], source: "at: aString ifPresent: aBlock\x0a\x09\x22return the evaluation of aBlock with the value if the property is defined or return nil\x22\x0a\x09<\x0a\x09\x09var obj = self['@jsObject'];\x0a\x09\x09return aString in obj ? aBlock._value_(obj[aString]) : nil;\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "at:ifPresent:ifAbsent:", category: 'accessing', fn: function (aString,aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var obj = self['@jsObject']; return aString in obj ? aBlock._value_(obj[aString]) : anotherBlock._value(); ; return self}, function($ctx1) {$ctx1.fill(self,"at:ifPresent:ifAbsent:",{aString:aString,aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.JSObjectProxy)})}, args: ["aString", "aBlock", "anotherBlock"], source: "at: aString ifPresent: aBlock ifAbsent: anotherBlock\x0a\x09\x22return the evaluation of aBlock with the value if the property is defined\x0a\x09or return value of anotherBlock\x22\x0a\x09<\x0a\x09\x09var obj = self['@jsObject'];\x0a\x09\x09return aString in obj ? aBlock._value_(obj[aString]) : anotherBlock._value();\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: 'accessing', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self['@jsObject'][aString] = anObject; return self}, function($ctx1) {$ctx1.fill(self,"at:put:",{aString:aString,anObject:anObject},smalltalk.JSObjectProxy)})}, args: ["aString", "anObject"], source: "at: aString put: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "doesNotUnderstand:", category: 'proxy', fn: function (aMessage){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._lookupProperty_(_st(_st(aMessage)._selector())._asJavaScriptSelector()); if(($receiver = $2) == nil || $receiver == undefined){ $1=smalltalk.JSObjectProxy.superclass.fn.prototype._doesNotUnderstand_.apply(_st(self), [aMessage]); } else { var jsSelector; jsSelector=$receiver; $1=self._forwardMessage_withArguments_(jsSelector,_st(aMessage)._arguments()); }; return $1; }, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage},smalltalk.JSObjectProxy)})}, args: ["aMessage"], source: "doesNotUnderstand: aMessage\x0a\x09^ (self lookupProperty: aMessage selector asJavaScriptSelector)\x0a\x09\x09ifNil: [ super doesNotUnderstand: aMessage ]\x0a\x09\x09ifNotNil: [ :jsSelector | \x0a\x09\x09\x09self \x0a\x09\x09\x09\x09forwardMessage: jsSelector \x0a\x09\x09\x09\x09withArguments: aMessage arguments ]", messageSends: ["ifNil:ifNotNil:", "doesNotUnderstand:", "forwardMessage:withArguments:", "arguments", "lookupProperty:", "asJavaScriptSelector", "selector"], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "forwardMessage:withArguments:", category: 'proxy', fn: function (aString,anArray){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.send(self._jsObject(), aString, anArray); ; return self}, function($ctx1) {$ctx1.fill(self,"forwardMessage:withArguments:",{aString:aString,anArray:anArray},smalltalk.JSObjectProxy)})}, args: ["aString", "anArray"], source: "forwardMessage: aString withArguments: anArray\x0a\x09<\x0a\x09\x09return smalltalk.send(self._jsObject(), aString, anArray);\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "inspectOn:", category: 'proxy', fn: function (anInspector){ var self=this; var variables; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { variables=_st($Dictionary())._new(); _st(variables)._at_put_("#self",self._jsObject()); _st(anInspector)._setLabel_(self._printString()); self._addObjectVariablesTo_(variables); _st(anInspector)._setVariables_(variables); return self}, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector,variables:variables},smalltalk.JSObjectProxy)})}, args: ["anInspector"], source: "inspectOn: anInspector\x0a\x09| variables |\x0a\x09variables := Dictionary new.\x0a\x09variables at: '#self' put: self jsObject.\x0a\x09anInspector setLabel: self printString.\x0a\x09self addObjectVariablesTo: variables.\x0a\x09anInspector setVariables: variables", messageSends: ["new", "at:put:", "jsObject", "setLabel:", "printString", "addObjectVariablesTo:", "setVariables:"], referencedClasses: ["Dictionary"] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "jsObject", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@jsObject"]; return $1; }, function($ctx1) {$ctx1.fill(self,"jsObject",{},smalltalk.JSObjectProxy)})}, args: [], source: "jsObject\x0a\x09^jsObject", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "jsObject:", category: 'accessing', fn: function (aJSObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@jsObject"]=aJSObject; return self}, function($ctx1) {$ctx1.fill(self,"jsObject:",{aJSObject:aJSObject},smalltalk.JSObjectProxy)})}, args: ["aJSObject"], source: "jsObject: aJSObject\x0a\x09jsObject := aJSObject", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "keysAndValuesDo:", category: 'enumerating', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var o = self['@jsObject']; for(var i in o) { aBlock._value_value_(i, o[i]); } ; return self}, function($ctx1) {$ctx1.fill(self,"keysAndValuesDo:",{aBlock:aBlock},smalltalk.JSObjectProxy)})}, args: ["aBlock"], source: "keysAndValuesDo: aBlock\x0a\x09<\x0a\x09\x09var o = self['@jsObject'];\x0a\x09\x09for(var i in o) {\x0a\x09\x09\x09aBlock._value_value_(i, o[i]);\x0a\x09\x09}\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "lookupProperty:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return aString in self._jsObject() ? aString : nil; return self}, function($ctx1) {$ctx1.fill(self,"lookupProperty:",{aString:aString},smalltalk.JSObjectProxy)})}, args: ["aString"], source: "lookupProperty: aString\x0a\x09\x22Looks up a property in JS object.\x0a\x09Answer the property if it is present, or nil if it is not present.\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aStream)._nextPutAll_(self._printString()); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.JSObjectProxy)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09aStream nextPutAll: self printString", messageSends: ["nextPutAll:", "printString"], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "printString", category: 'printing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var js = self['@jsObject']; return js.toString ? js.toString() : Object.prototype.toString.call(js) ; return self}, function($ctx1) {$ctx1.fill(self,"printString",{},smalltalk.JSObjectProxy)})}, args: [], source: "printString\x0a\x09<\x0a\x09\x09var js = self['@jsObject'];\x0a\x09\x09return js.toString\x0a\x09\x09\x09? js.toString()\x0a\x09\x09\x09: Object.prototype.toString.call(js)\x0a\x09>", messageSends: [], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._at_ifAbsent_("value",(function(){ return smalltalk.withContext(function($ctx2) { return smalltalk.JSObjectProxy.superclass.fn.prototype._value.apply(_st(self), []); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.JSObjectProxy)})}, args: [], source: "value\x0a\x09\x22if attribute 'value' exists on the JS object return it,\x0a\x09otherwise return the result of Object>>value.\x22\x0a\x09\x0a\x09^ self \x0a\x09\x09at: 'value' \x0a\x09\x09ifAbsent: [ super value ]", messageSends: ["at:ifAbsent:", "value"], referencedClasses: [] }), smalltalk.JSObjectProxy); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (aJSObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._jsObject_(aJSObject); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{aJSObject:aJSObject},smalltalk.JSObjectProxy.klass)})}, args: ["aJSObject"], source: "on: aJSObject\x0a\x09^self new\x0a\x09\x09jsObject: aJSObject;\x0a\x09\x09yourself", messageSends: ["jsObject:", "new", "yourself"], referencedClasses: [] }), smalltalk.JSObjectProxy.klass); smalltalk.addClass('Organizer', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.Organizer.comment="I represent categorization information. \x0a\x0a## API\x0a\x0aUse `#addElement:` and `#removeElement:` to manipulate instances."; smalltalk.addMethod( smalltalk.method({ selector: "addElement:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self.elements.addElement(anObject); return self}, function($ctx1) {$ctx1.fill(self,"addElement:",{anObject:anObject},smalltalk.Organizer)})}, args: ["anObject"], source: "addElement: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Organizer); smalltalk.addMethod( smalltalk.method({ selector: "elements", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._basicAt_("elements"))._copy(); return $1; }, function($ctx1) {$ctx1.fill(self,"elements",{},smalltalk.Organizer)})}, args: [], source: "elements\x0a\x09^ (self basicAt: 'elements') copy", messageSends: ["copy", "basicAt:"], referencedClasses: [] }), smalltalk.Organizer); smalltalk.addMethod( smalltalk.method({ selector: "removeElement:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self.elements.removeElement(anObject); return self}, function($ctx1) {$ctx1.fill(self,"removeElement:",{anObject:anObject},smalltalk.Organizer)})}, args: ["anObject"], source: "removeElement: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Organizer); smalltalk.addClass('ClassOrganizer', smalltalk.Organizer, [], 'Kernel-Infrastructure'); smalltalk.ClassOrganizer.comment="I am an organizer specific to classes. I hold method categorization information for classes."; smalltalk.addMethod( smalltalk.method({ selector: "addElement:", category: 'accessing', fn: function (aString){ var self=this; function $ProtocolAdded(){return smalltalk.ProtocolAdded||(typeof ProtocolAdded=="undefined"?nil:ProtocolAdded)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.ClassOrganizer.superclass.fn.prototype._addElement_.apply(_st(self), [aString]); $1=_st($ProtocolAdded())._new(); _st($1)._protocol_(aString); _st($1)._theClass_(self._theClass()); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"addElement:",{aString:aString},smalltalk.ClassOrganizer)})}, args: ["aString"], source: "addElement: aString\x0a\x09super addElement: aString.\x0a\x0a\x09SystemAnnouncer current announce: (ProtocolAdded new\x0a\x09\x09protocol: aString;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09yourself)", messageSends: ["addElement:", "announce:", "protocol:", "new", "theClass:", "theClass", "yourself", "current"], referencedClasses: ["ProtocolAdded", "SystemAnnouncer"] }), smalltalk.ClassOrganizer); smalltalk.addMethod( smalltalk.method({ selector: "removeElement:", category: 'accessing', fn: function (aString){ var self=this; function $ProtocolRemoved(){return smalltalk.ProtocolRemoved||(typeof ProtocolRemoved=="undefined"?nil:ProtocolRemoved)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.ClassOrganizer.superclass.fn.prototype._removeElement_.apply(_st(self), [aString]); $1=_st($ProtocolRemoved())._new(); _st($1)._protocol_(aString); _st($1)._theClass_(self._theClass()); $2=_st($1)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($2); return self}, function($ctx1) {$ctx1.fill(self,"removeElement:",{aString:aString},smalltalk.ClassOrganizer)})}, args: ["aString"], source: "removeElement: aString\x0a\x09super removeElement: aString.\x0a\x0a\x09SystemAnnouncer current announce: (ProtocolRemoved new\x0a\x09\x09protocol: aString;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09yourself)", messageSends: ["removeElement:", "announce:", "protocol:", "new", "theClass:", "theClass", "yourself", "current"], referencedClasses: ["ProtocolRemoved", "SystemAnnouncer"] }), smalltalk.ClassOrganizer); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.theClass ; return self}, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.ClassOrganizer)})}, args: [], source: "theClass\x0a\x09< return self.theClass >", messageSends: [], referencedClasses: [] }), smalltalk.ClassOrganizer); smalltalk.addClass('PackageOrganizer', smalltalk.Organizer, [], 'Kernel-Infrastructure'); smalltalk.PackageOrganizer.comment="I am an organizer specific to packages. I hold classes categorization information."; smalltalk.addClass('Package', smalltalk.Object, ['transport'], 'Kernel-Infrastructure'); smalltalk.Package.comment="I am similar to a \x22class category\x22 typically found in other Smalltalks like Pharo or Squeak. Amber does not have class categories anymore, it had in the beginning but now each class in the system knows which package it belongs to.\x0a\x0aEach package has a name and can be queried for its classes, but it will then resort to a reverse scan of all classes to find them.\x0a\x0a## API\x0a\x0aPackages are manipulated through \x22Smalltalk current\x22, like for example finding one based on a name or with `Package class >> #name` directly:\x0a\x0a Smalltalk current packageAt: 'Kernel'\x0a Package named: 'Kernel'\x0a\x0aA package differs slightly from a Monticello package which can span multiple class categories using a naming convention based on hyphenation. But just as in Monticello a package supports \x22class extensions\x22 so a package can define behaviors in foreign classes using a naming convention for method categories where the category starts with an asterisk and then the name of the owning package follows.\x0a\x0aYou can fetch a package from the server:\x0a\x0a\x09Package load: 'Additional-Examples'"; smalltalk.addMethod( smalltalk.method({ selector: "basicTransport", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.transport; return self}, function($ctx1) {$ctx1.fill(self,"basicTransport",{},smalltalk.Package)})}, args: [], source: "basicTransport\x0a\x09\x22Answer the transport literal JavaScript object as setup in the JavaScript file, if any\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "classes", category: 'classes', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(self._organization())._elements())._asSet())._asArray(); return $1; }, function($ctx1) {$ctx1.fill(self,"classes",{},smalltalk.Package)})}, args: [], source: "classes\x0a\x09^ self organization elements asSet asArray", messageSends: ["asArray", "asSet", "elements", "organization"], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "isPackage", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isPackage",{},smalltalk.Package)})}, args: [], source: "isPackage\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "loadDependencies", category: 'dependencies', fn: function (){ var self=this; var classes,packages; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; classes=self._loadDependencyClasses(); $2=_st(_st(classes)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._package(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._asSet(); _st($2)._remove_ifAbsent_(self,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"loadDependencies",{classes:classes,packages:packages},smalltalk.Package)})}, args: [], source: "loadDependencies\x0a\x09\x22Returns list of packages that need to be loaded\x0a\x09before loading this package.\x22\x0a\x09\x0a\x09| classes packages |\x0a\x09classes := self loadDependencyClasses.\x0a\x09^(classes collect: [ :each | each package ]) asSet\x0a\x09\x09remove: self ifAbsent: [];\x0a\x09\x09yourself", messageSends: ["loadDependencyClasses", "remove:ifAbsent:", "asSet", "collect:", "package", "yourself"], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "loadDependencyClasses", category: 'dependencies', fn: function (){ var self=this; var starCategoryName; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; starCategoryName="*".__comma(self._name()); $2=_st(_st(self._classes())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._superclass(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._asSet(); _st($2)._remove_ifAbsent_(nil,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st($2)._addAll_(_st(_st(_st($Smalltalk())._current())._classes())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._protocols())._includes_(starCategoryName); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}))); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"loadDependencyClasses",{starCategoryName:starCategoryName},smalltalk.Package)})}, args: [], source: "loadDependencyClasses\x0a\x09\x22Returns classes needed at the time of loading a package.\x0a\x09These are all that are used to subclass\x0a\x09and to define an extension method\x22\x0a\x09\x0a\x09| starCategoryName |\x0a\x09starCategoryName := '*', self name.\x0a\x09^(self classes collect: [ :each | each superclass ]) asSet\x0a\x09\x09remove: nil ifAbsent: [];\x0a\x09\x09addAll: (Smalltalk current classes select: [ :each | each protocols includes: starCategoryName ]);\x0a\x09\x09yourself", messageSends: [",", "name", "remove:ifAbsent:", "asSet", "collect:", "superclass", "classes", "addAll:", "select:", "includes:", "protocols", "current", "yourself"], referencedClasses: ["Smalltalk"] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "name", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.pkgName; return self}, function($ctx1) {$ctx1.fill(self,"name",{},smalltalk.Package)})}, args: [], source: "name\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "name:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self.pkgName = aString; return self}, function($ctx1) {$ctx1.fill(self,"name:",{aString:aString},smalltalk.Package)})}, args: ["aString"], source: "name: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "organization", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_("organization"); return $1; }, function($ctx1) {$ctx1.fill(self,"organization",{},smalltalk.Package)})}, args: [], source: "organization\x0a\x09^ self basicAt: 'organization'", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "printOn:", category: 'printing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.Package.superclass.fn.prototype._printOn_.apply(_st(self), [aStream]); $1=aStream; _st($1)._nextPutAll_(" ("); _st($1)._nextPutAll_(self._name()); $2=_st($1)._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"printOn:",{aStream:aStream},smalltalk.Package)})}, args: ["aStream"], source: "printOn: aStream\x0a\x09super printOn: aStream.\x0a\x09aStream \x0a\x09\x09nextPutAll: ' (';\x0a\x09\x09nextPutAll: self name;\x0a\x09\x09nextPutAll: ')'", messageSends: ["printOn:", "nextPutAll:", "name"], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "setupClasses", category: 'classes', fn: function (){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self._classes(); _st($1)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st($ClassBuilder())._new())._setupClass_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=_st($1)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._initialize(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"setupClasses",{},smalltalk.Package)})}, args: [], source: "setupClasses\x0a\x09self classes\x0a\x09\x09do: [ :each | ClassBuilder new setupClass: each ];\x0a\x09\x09do: [ :each | each initialize ]", messageSends: ["do:", "setupClass:", "new", "classes", "initialize"], referencedClasses: ["ClassBuilder"] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "sortedClasses", category: 'classes', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._class())._sortedClasses_(self._classes()); return $1; }, function($ctx1) {$ctx1.fill(self,"sortedClasses",{},smalltalk.Package)})}, args: [], source: "sortedClasses\x0a\x09\x22Answer all classes in the receiver, sorted by superclass/subclasses and by class name for common subclasses (Issue #143).\x22\x0a\x0a\x09^ self class sortedClasses: self classes", messageSends: ["sortedClasses:", "classes", "class"], referencedClasses: [] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "transport", category: 'accessing', fn: function (){ var self=this; function $PackageTransport(){return smalltalk.PackageTransport||(typeof PackageTransport=="undefined"?nil:PackageTransport)} return smalltalk.withContext(function($ctx1) { var $2,$3,$4,$1; $2=self["@transport"]; if(($receiver = $2) == nil || $receiver == undefined){ $3=_st($PackageTransport())._fromJson_(self._basicTransport()); _st($3)._package_(self); $4=_st($3)._yourself(); self["@transport"]=$4; $1=self["@transport"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"transport",{},smalltalk.Package)})}, args: [], source: "transport\x0a\x09^ transport ifNil: [ \x0a\x09\x09transport := (PackageTransport fromJson: self basicTransport)\x0a\x09\x09\x09package: self;\x0a\x09\x09\x09yourself ]", messageSends: ["ifNil:", "package:", "fromJson:", "basicTransport", "yourself"], referencedClasses: ["PackageTransport"] }), smalltalk.Package); smalltalk.addMethod( smalltalk.method({ selector: "transport:", category: 'accessing', fn: function (aPackageTransport){ var self=this; return smalltalk.withContext(function($ctx1) { self["@transport"]=aPackageTransport; return self}, function($ctx1) {$ctx1.fill(self,"transport:",{aPackageTransport:aPackageTransport},smalltalk.Package)})}, args: ["aPackageTransport"], source: "transport: aPackageTransport\x0a\x09transport := aPackageTransport", messageSends: [], referencedClasses: [] }), smalltalk.Package); smalltalk.Package.klass.iVarNames = ['defaultCommitPathJs','defaultCommitPathSt']; smalltalk.addMethod( smalltalk.method({ selector: "named:", category: 'accessing', fn: function (aPackageName){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._packageAt_(aPackageName); return $1; }, function($ctx1) {$ctx1.fill(self,"named:",{aPackageName:aPackageName},smalltalk.Package.klass)})}, args: ["aPackageName"], source: "named: aPackageName\x0a\x0a\x09^Smalltalk current packageAt: aPackageName", messageSends: ["packageAt:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Package.klass); smalltalk.addMethod( smalltalk.method({ selector: "named:ifAbsent:", category: 'accessing', fn: function (aPackageName,aBlock){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._packageAt_ifAbsent_(aPackageName,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"named:ifAbsent:",{aPackageName:aPackageName,aBlock:aBlock},smalltalk.Package.klass)})}, args: ["aPackageName", "aBlock"], source: "named: aPackageName ifAbsent: aBlock\x0a\x0a\x09^Smalltalk current packageAt: aPackageName ifAbsent: aBlock", messageSends: ["packageAt:ifAbsent:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Package.klass); smalltalk.addMethod( smalltalk.method({ selector: "sortedClasses:", category: 'sorting', fn: function (classes){ var self=this; var children,others,nodes,expandedClasses; function $ClassSorterNode(){return smalltalk.ClassSorterNode||(typeof ClassSorterNode=="undefined"?nil:ClassSorterNode)} function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1,$2; children=[]; others=[]; _st(classes)._do_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st(classes)._includes_(_st(each)._superclass()); if(smalltalk.assert($1)){ return _st(others)._add_(each); } else { return _st(children)._add_(each); }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); nodes=_st(children)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st($ClassSorterNode())._on_classes_level_(each,others,(0)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); nodes=_st(nodes)._sorted_((function(a,b){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(a)._theClass())._name()).__lt_eq(_st(_st(b)._theClass())._name()); }, function($ctx2) {$ctx2.fillBlock({a:a,b:b},$ctx1)})})); expandedClasses=_st($Array())._new(); _st(nodes)._do_((function(aNode){ return smalltalk.withContext(function($ctx2) { return _st(aNode)._traverseClassesWith_(expandedClasses); }, function($ctx2) {$ctx2.fillBlock({aNode:aNode},$ctx1)})})); $2=expandedClasses; return $2; }, function($ctx1) {$ctx1.fill(self,"sortedClasses:",{classes:classes,children:children,others:others,nodes:nodes,expandedClasses:expandedClasses},smalltalk.Package.klass)})}, args: ["classes"], source: "sortedClasses: classes\x0a\x09\x22Answer classes, sorted by superclass/subclasses and by class name for common subclasses (Issue #143)\x22\x0a\x0a\x09| children others nodes expandedClasses |\x0a\x09children := #().\x0a\x09others := #().\x0a\x09classes do: [:each |\x0a\x09\x09(classes includes: each superclass)\x0a\x09\x09\x09ifFalse: [children add: each]\x0a\x09\x09\x09ifTrue: [others add: each]].\x0a\x09nodes := children collect: [:each |\x0a\x09\x09ClassSorterNode on: each classes: others level: 0].\x0a\x09nodes := nodes sorted: [:a :b | a theClass name <= b theClass name ].\x0a\x09expandedClasses := Array new.\x0a\x09nodes do: [:aNode |\x0a\x09\x09aNode traverseClassesWith: expandedClasses].\x0a\x09^expandedClasses", messageSends: ["do:", "ifFalse:ifTrue:", "add:", "includes:", "superclass", "collect:", "on:classes:level:", "sorted:", "<=", "name", "theClass", "new", "traverseClassesWith:"], referencedClasses: ["ClassSorterNode", "Array"] }), smalltalk.Package.klass); smalltalk.addClass('PlatformInterface', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.PlatformInterface.comment="I am single entry point to UI and environment interface.\x0aMy `initialize` tries several options (for now, browser environment only) to set myself up.\x0a\x0a## API\x0a\x0a PlatformInterface alert: 'Hey, there is a problem'.\x0a PlatformInterface confirm: 'Affirmative?'.\x0a PlatformInterface prompt: 'Your name:'.\x0a\x0a PlatformInterface ajax: #{\x0a 'url' -> '/patch.js'. 'type' -> 'GET'. dataType->'script'\x0a }."; smalltalk.PlatformInterface.klass.iVarNames = ['worker']; smalltalk.addMethod( smalltalk.method({ selector: "ajax:", category: 'actions', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@worker"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=self._error_("ajax: not available"); } else { $1=_st(self["@worker"])._ajax_(anObject); }; return $1; }, function($ctx1) {$ctx1.fill(self,"ajax:",{anObject:anObject},smalltalk.PlatformInterface.klass)})}, args: ["anObject"], source: "ajax: anObject\x0a\x09^worker\x0a\x09\x09ifNotNil: [ worker ajax: anObject ]\x0a\x09\x09ifNil: [ self error: 'ajax: not available' ]", messageSends: ["ifNotNil:ifNil:", "ajax:", "error:"], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "alert:", category: 'actions', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@worker"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=self._error_("alert: not available"); } else { $1=_st(self["@worker"])._alert_(aString); }; return $1; }, function($ctx1) {$ctx1.fill(self,"alert:",{aString:aString},smalltalk.PlatformInterface.klass)})}, args: ["aString"], source: "alert: aString\x0a\x09^worker\x0a\x09\x09ifNotNil: [ worker alert: aString ]\x0a\x09\x09ifNil: [ self error: 'alert: not available' ]", messageSends: ["ifNotNil:ifNil:", "alert:", "error:"], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "confirm:", category: 'actions', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@worker"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=self._error_("confirm: not available"); } else { $1=_st(self["@worker"])._confirm_(aString); }; return $1; }, function($ctx1) {$ctx1.fill(self,"confirm:",{aString:aString},smalltalk.PlatformInterface.klass)})}, args: ["aString"], source: "confirm: aString\x0a\x09^worker\x0a\x09\x09ifNotNil: [ worker confirm: aString ]\x0a\x09\x09ifNil: [ self error: 'confirm: not available' ]", messageSends: ["ifNotNil:ifNil:", "confirm:", "error:"], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "existsGlobal:", category: 'actions', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var f = new Function('aString', 'if (/^[0-9]/.test(aString) || !/^[\\w_]+$/.test(aString))\n'+ ' return false;\n'+ 'try { eval(aString); return true; } catch (ex) {}\n'+ 'return false;'); return f(aString);; return self}, function($ctx1) {$ctx1.fill(self,"existsGlobal:",{aString:aString},smalltalk.PlatformInterface.klass)})}, args: ["aString"], source: "existsGlobal: aString\x0a<\x0a\x09var f = new Function('aString',\x0a\x09'if (/^[0-9]/.test(aString) || !/^[\x5c\x5cw_]+$/.test(aString))\x5cn'+\x0a\x09'\x09return false;\x5cn'+\x0a\x09'try { eval(aString); return true; } catch (ex) {}\x5cn'+\x0a\x09'return false;');\x0a\x09return f(aString);\x0a>", messageSends: [], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; var candidate; function $BrowserInterface(){return smalltalk.BrowserInterface||(typeof BrowserInterface=="undefined"?nil:BrowserInterface)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; smalltalk.PlatformInterface.klass.superclass.fn.prototype._initialize.apply(_st(self), []); $1=$BrowserInterface(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { candidate=_st($BrowserInterface())._new(); candidate; $2=_st(candidate)._isAvailable(); if(smalltalk.assert($2)){ self._setWorker_(candidate); $3=self; return $3; }; }; return self}, function($ctx1) {$ctx1.fill(self,"initialize",{candidate:candidate},smalltalk.PlatformInterface.klass)})}, args: [], source: "initialize\x0a\x09| candidate |\x0a\x09\x0a\x09super initialize.\x0a\x09\x0a\x09BrowserInterface ifNotNil: [\x0a\x09\x09candidate := BrowserInterface new.\x0a\x09\x09candidate isAvailable ifTrue: [ self setWorker: candidate. ^self ]\x0a\x09]", messageSends: ["initialize", "ifNotNil:", "new", "ifTrue:", "setWorker:", "isAvailable"], referencedClasses: ["BrowserInterface"] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "prompt:", category: 'actions', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@worker"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=self._error_("prompt: not available"); } else { $1=_st(self["@worker"])._prompt_(aString); }; return $1; }, function($ctx1) {$ctx1.fill(self,"prompt:",{aString:aString},smalltalk.PlatformInterface.klass)})}, args: ["aString"], source: "prompt: aString\x0a\x09^worker\x0a\x09\x09ifNotNil: [ worker prompt: aString ]\x0a\x09\x09ifNil: [ self error: 'prompt: not available' ]", messageSends: ["ifNotNil:ifNil:", "prompt:", "error:"], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addMethod( smalltalk.method({ selector: "setWorker:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@worker"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"setWorker:",{anObject:anObject},smalltalk.PlatformInterface.klass)})}, args: ["anObject"], source: "setWorker: anObject\x0a\x09worker := anObject", messageSends: [], referencedClasses: [] }), smalltalk.PlatformInterface.klass); smalltalk.addClass('ProgressHandler', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.ProgressHandler.comment="I am used to manage progress in collection iterations, see `SequenceableCollection >> #do:displayingProgress:`.\x0a\x0aSubclasses of can register themselves as the current handler with\x0a`ProgressHandler class >> register`.\x0a\x0aThe default behavior is to simply iterate over the collection."; smalltalk.addMethod( smalltalk.method({ selector: "do:on:displaying:", category: 'progress handling', fn: function (aBlock,aCollection,aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aCollection)._do_(aBlock); return self}, function($ctx1) {$ctx1.fill(self,"do:on:displaying:",{aBlock:aBlock,aCollection:aCollection,aString:aString},smalltalk.ProgressHandler)})}, args: ["aBlock", "aCollection", "aString"], source: "do: aBlock on: aCollection displaying: aString\x0a\x09aCollection do: aBlock", messageSends: ["do:"], referencedClasses: [] }), smalltalk.ProgressHandler); smalltalk.ProgressHandler.klass.iVarNames = ['current']; smalltalk.addMethod( smalltalk.method({ selector: "current", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@current"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@current"]=self._new(); $1=self["@current"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"current",{},smalltalk.ProgressHandler.klass)})}, args: [], source: "current\x0a\x09^current ifNil: [ current := self new ]", messageSends: ["ifNil:", "new"], referencedClasses: [] }), smalltalk.ProgressHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._register(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ProgressHandler.klass)})}, args: [], source: "initialize\x0a\x09self register", messageSends: ["register"], referencedClasses: [] }), smalltalk.ProgressHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "register", category: 'initialization', fn: function (){ var self=this; function $ProgressHandler(){return smalltalk.ProgressHandler||(typeof ProgressHandler=="undefined"?nil:ProgressHandler)} return smalltalk.withContext(function($ctx1) { _st($ProgressHandler())._setCurrent_(self._new()); return self}, function($ctx1) {$ctx1.fill(self,"register",{},smalltalk.ProgressHandler.klass)})}, args: [], source: "register\x0a\x09ProgressHandler setCurrent: self new", messageSends: ["setCurrent:", "new"], referencedClasses: ["ProgressHandler"] }), smalltalk.ProgressHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "setCurrent:", category: 'accessing', fn: function (anHandler){ var self=this; return smalltalk.withContext(function($ctx1) { self["@current"]=anHandler; return self}, function($ctx1) {$ctx1.fill(self,"setCurrent:",{anHandler:anHandler},smalltalk.ProgressHandler.klass)})}, args: ["anHandler"], source: "setCurrent: anHandler\x0a\x09current := anHandler", messageSends: [], referencedClasses: [] }), smalltalk.ProgressHandler.klass); smalltalk.addClass('Smalltalk', smalltalk.Object, [], 'Kernel-Infrastructure'); smalltalk.Smalltalk.comment="I represent the global JavaScript variable `smalltalk` declared in `js/boot.js`.\x0a\x0a## API\x0a\x0aI have only one instance, accessed with class-side method `#current`.\x0a\x0aThe `smalltalk` object holds all class and packages defined in the system.\x0a\x0a## Classes\x0a\x0aClasses can be accessed using the following methods:\x0a\x0a- `#classes` answers the full list of Smalltalk classes in the system\x0a- `#at:` answers a specific class or `nil`\x0a\x0a## Packages\x0a\x0aPackages can be accessed using the following methods:\x0a\x0a- `#packages` answers the full list of packages\x0a- `#packageAt:` answers a specific package or `nil`\x0a\x0a## Parsing\x0a\x0aThe `#parse:` method is used to parse Amber source code.\x0aIt requires the `Compiler` package and the `js/parser.js` parser file in order to work."; smalltalk.addMethod( smalltalk.method({ selector: "addGlobalJsVariable:", category: 'globals', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._globalJsVariables())._add_(aString); return self}, function($ctx1) {$ctx1.fill(self,"addGlobalJsVariable:",{aString:aString},smalltalk.Smalltalk)})}, args: ["aString"], source: "addGlobalJsVariable: aString\x0a\x09self globalJsVariables add: aString", messageSends: ["add:", "globalJsVariables"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "amdRequire", category: 'accessing amd', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._at_("amdRequire"); return $1; }, function($ctx1) {$ctx1.fill(self,"amdRequire",{},smalltalk.Smalltalk)})}, args: [], source: "amdRequire\x0a\x09^ self at: 'amdRequire'", messageSends: ["at:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "asSmalltalkException:", category: 'error handling', fn: function (anObject){ var self=this; function $JavaScriptException(){return smalltalk.JavaScriptException||(typeof JavaScriptException=="undefined"?nil:JavaScriptException)} function $Error(){return smalltalk.Error||(typeof Error=="undefined"?nil:Error)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(self._isSmalltalkObject_(anObject))._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(anObject)._isKindOf_($Error()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($2)){ $1=anObject; } else { $1=_st($JavaScriptException())._on_(anObject); }; return $1; }, function($ctx1) {$ctx1.fill(self,"asSmalltalkException:",{anObject:anObject},smalltalk.Smalltalk)})}, args: ["anObject"], source: "asSmalltalkException: anObject\x0a\x09\x22A JavaScript exception may be thrown.\x0a\x09We then need to convert it back to a Smalltalk object\x22\x0a\x09\x0a\x09^ ((self isSmalltalkObject: anObject) and: [ anObject isKindOf: Error ])\x0a\x09\x09ifTrue: [ anObject ]\x0a\x09\x09ifFalse: [ JavaScriptException on: anObject ]", messageSends: ["ifTrue:ifFalse:", "on:", "and:", "isKindOf:", "isSmalltalkObject:"], referencedClasses: ["JavaScriptException", "Error"] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "at:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"at:",{aString:aString},smalltalk.Smalltalk)})}, args: ["aString"], source: "at: aString\x0a\x09^ self basicAt: aString", messageSends: ["basicAt:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "at:put:", category: 'accessing', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._basicAt_put_(aString,anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"at:put:",{aString:aString,anObject:anObject},smalltalk.Smalltalk)})}, args: ["aString", "anObject"], source: "at: aString put: anObject\x0a\x09^ self basicAt: aString put: anObject", messageSends: ["basicAt:put:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "basicParse:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.parser.parse(aString); return self}, function($ctx1) {$ctx1.fill(self,"basicParse:",{aString:aString},smalltalk.Smalltalk)})}, args: ["aString"], source: "basicParse: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "classes", category: 'classes', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.classes(); return self}, function($ctx1) {$ctx1.fill(self,"classes",{},smalltalk.Smalltalk)})}, args: [], source: "classes\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "createPackage:", category: 'packages', fn: function (packageName){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk.addPackage(packageName); return self}, function($ctx1) {$ctx1.fill(self,"createPackage:",{packageName:packageName},smalltalk.Smalltalk)})}, args: ["packageName"], source: "createPackage: packageName\x0a\x09\x22Create and bind a new bare package with given name and return it.\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "createPackage:properties:", category: 'private', fn: function (packageName,aDict){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self._deprecatedAPI(); $1=_st(aDict)._isEmpty(); if(! smalltalk.assert($1)){ self._error_("createPackage:properties: called with nonempty properties"); }; $2=self._createPackage_(packageName); return $2; }, function($ctx1) {$ctx1.fill(self,"createPackage:properties:",{packageName:packageName,aDict:aDict},smalltalk.Smalltalk)})}, args: ["packageName", "aDict"], source: "createPackage: packageName properties: aDict\x0a\x09\x22Needed to import .st files: they begin with this call.\x22\x0a\x09self deprecatedAPI.\x0a\x09\x0a\x09aDict isEmpty ifFalse: [ self error: 'createPackage:properties: called with nonempty properties' ].\x0a\x09^ self createPackage: packageName", messageSends: ["deprecatedAPI", "ifFalse:", "error:", "isEmpty", "createPackage:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "defaultAmdNamespace", category: 'accessing amd', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._at_("defaultAmdNamespace"); return $1; }, function($ctx1) {$ctx1.fill(self,"defaultAmdNamespace",{},smalltalk.Smalltalk)})}, args: [], source: "defaultAmdNamespace\x0a\x09^ self at: 'defaultAmdNamespace'", messageSends: ["at:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "defaultAmdNamespace:", category: 'accessing amd', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._at_put_("defaultAmdNamespace",aString); return self}, function($ctx1) {$ctx1.fill(self,"defaultAmdNamespace:",{aString:aString},smalltalk.Smalltalk)})}, args: ["aString"], source: "defaultAmdNamespace: aString\x0a\x09self at: 'defaultAmdNamespace' put: aString", messageSends: ["at:put:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "deleteClass:", category: 'private', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self.removeClass(aClass); return self}, function($ctx1) {$ctx1.fill(self,"deleteClass:",{aClass:aClass},smalltalk.Smalltalk)})}, args: ["aClass"], source: "deleteClass: aClass\x0a\x09\x22Deletes a class by deleting its binding only. Use #removeClass instead\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "deleteGlobalJsVariable:", category: 'globals', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._globalJsVariables())._remove_ifAbsent_(aString,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"deleteGlobalJsVariable:",{aString:aString},smalltalk.Smalltalk)})}, args: ["aString"], source: "deleteGlobalJsVariable: aString\x0a\x09self globalJsVariables remove: aString ifAbsent:[]", messageSends: ["remove:ifAbsent:", "globalJsVariables"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "deletePackage:", category: 'private', fn: function (packageName){ var self=this; return smalltalk.withContext(function($ctx1) { delete self.packages[packageName]; return self}, function($ctx1) {$ctx1.fill(self,"deletePackage:",{packageName:packageName},smalltalk.Smalltalk)})}, args: ["packageName"], source: "deletePackage: packageName\x0a\x09\x22Deletes a package by deleting its binding, but does not check if it contains classes etc.\x0a\x09To remove a package, use #removePackage instead.\x22\x0a\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "globalJsVariables", category: 'globals', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.globalJsVariables; return self}, function($ctx1) {$ctx1.fill(self,"globalJsVariables",{},smalltalk.Smalltalk)})}, args: [], source: "globalJsVariables\x0a\x09\x22Array of global JavaScript variables\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "isSmalltalkObject:", category: 'testing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { return typeof anObject.klass !== 'undefined'; return self}, function($ctx1) {$ctx1.fill(self,"isSmalltalkObject:",{anObject:anObject},smalltalk.Smalltalk)})}, args: ["anObject"], source: "isSmalltalkObject: anObject\x0a\x09\x22Consider anObject a Smalltalk object if it has a 'klass' property.\x0a\x09Note that this may be unaccurate\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "packageAt:", category: 'packages', fn: function (packageName){ var self=this; return smalltalk.withContext(function($ctx1) { return self.packages[packageName]; return self}, function($ctx1) {$ctx1.fill(self,"packageAt:",{packageName:packageName},smalltalk.Smalltalk)})}, args: ["packageName"], source: "packageAt: packageName\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "packageAt:ifAbsent:", category: 'packages', fn: function (packageName,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._packageAt_(packageName); $1=_st($2)._ifNil_(aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"packageAt:ifAbsent:",{packageName:packageName,aBlock:aBlock},smalltalk.Smalltalk)})}, args: ["packageName", "aBlock"], source: "packageAt: packageName ifAbsent: aBlock\x0a\x09^(self packageAt: packageName) ifNil: aBlock", messageSends: ["ifNil:", "packageAt:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "packages", category: 'packages', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.packages.all(); return self}, function($ctx1) {$ctx1.fill(self,"packages",{},smalltalk.Smalltalk)})}, args: [], source: "packages\x0a\x09\x22Return all Package instances in the system.\x22\x0a\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "parse:", category: 'accessing', fn: function (aString){ var self=this; var result; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; self._try_catch_((function(){ return smalltalk.withContext(function($ctx2) { result=self._basicParse_(aString); return result; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(ex){ return smalltalk.withContext(function($ctx2) { return _st(self._parseError_parsing_(ex,aString))._signal(); }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1)})})); $2=result; _st($2)._source_(aString); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString,result:result},smalltalk.Smalltalk)})}, args: ["aString"], source: "parse: aString\x0a\x09| result |\x0a\x09\x0a\x09self \x0a\x09\x09try: [result := self basicParse: aString] \x0a\x09\x09catch: [:ex | (self parseError: ex parsing: aString) signal].\x0a\x09\x09\x0a\x09^ result\x0a\x09\x09source: aString;\x0a\x09\x09yourself", messageSends: ["try:catch:", "basicParse:", "signal", "parseError:parsing:", "source:", "yourself"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "parseError:parsing:", category: 'error handling', fn: function (anException,aString){ var self=this; function $ParseError(){return smalltalk.ParseError||(typeof ParseError=="undefined"?nil:ParseError)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($ParseError())._new())._messageText_(_st(_st(_st(_st("Parse error on line ".__comma(_st(anException)._basicAt_("line"))).__comma(" column ")).__comma(_st(anException)._basicAt_("column"))).__comma(" : Unexpected character ")).__comma(_st(anException)._basicAt_("found"))); return $1; }, function($ctx1) {$ctx1.fill(self,"parseError:parsing:",{anException:anException,aString:aString},smalltalk.Smalltalk)})}, args: ["anException", "aString"], source: "parseError: anException parsing: aString\x0a\x09^ ParseError new messageText: 'Parse error on line ', (anException basicAt: 'line') ,' column ' , (anException basicAt: 'column') ,' : Unexpected character ', (anException basicAt: 'found')", messageSends: ["messageText:", ",", "basicAt:", "new"], referencedClasses: ["ParseError"] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "pseudoVariableNames", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=["self", "super", "nil", "true", "false", "thisContext"]; return $1; }, function($ctx1) {$ctx1.fill(self,"pseudoVariableNames",{},smalltalk.Smalltalk)})}, args: [], source: "pseudoVariableNames\x0a\x09^ #('self' 'super' 'nil' 'true' 'false' 'thisContext')", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "readJSObject:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { return self.readJSObject(anObject); return self}, function($ctx1) {$ctx1.fill(self,"readJSObject:",{anObject:anObject},smalltalk.Smalltalk)})}, args: ["anObject"], source: "readJSObject: anObject\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "removeClass:", category: 'classes', fn: function (aClass){ var self=this; function $ClassRemoved(){return smalltalk.ClassRemoved||(typeof ClassRemoved=="undefined"?nil:ClassRemoved)} function $SystemAnnouncer(){return smalltalk.SystemAnnouncer||(typeof SystemAnnouncer=="undefined"?nil:SystemAnnouncer)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(aClass)._isMetaclass(); if(smalltalk.assert($1)){ self._error_(_st(_st(aClass)._asString()).__comma(" is a Metaclass and cannot be removed!")); }; self._deleteClass_(aClass); $2=_st($ClassRemoved())._new(); _st($2)._theClass_(aClass); $3=_st($2)._yourself(); _st(_st($SystemAnnouncer())._current())._announce_($3); return self}, function($ctx1) {$ctx1.fill(self,"removeClass:",{aClass:aClass},smalltalk.Smalltalk)})}, args: ["aClass"], source: "removeClass: aClass\x0a\x09aClass isMetaclass ifTrue: [self error: aClass asString, ' is a Metaclass and cannot be removed!'].\x0a\x09\x0a\x09self deleteClass: aClass.\x0a\x09\x0a\x09SystemAnnouncer current\x0a\x09\x09announce: (ClassRemoved new\x0a\x09\x09\x09theClass: aClass;\x0a\x09\x09\x09yourself)", messageSends: ["ifTrue:", "error:", ",", "asString", "isMetaclass", "deleteClass:", "announce:", "theClass:", "new", "yourself", "current"], referencedClasses: ["ClassRemoved", "SystemAnnouncer"] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "removePackage:", category: 'packages', fn: function (packageName){ var self=this; var pkg; return smalltalk.withContext(function($ctx1) { pkg=self._packageAt_ifAbsent_(packageName,(function(){ return smalltalk.withContext(function($ctx2) { return self._error_("Missing package: ".__comma(packageName)); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(_st(pkg)._classes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return self._removeClass_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); self._deletePackage_(packageName); return self}, function($ctx1) {$ctx1.fill(self,"removePackage:",{packageName:packageName,pkg:pkg},smalltalk.Smalltalk)})}, args: ["packageName"], source: "removePackage: packageName\x0a\x09\x22Removes a package and all its classes.\x22\x0a\x0a\x09| pkg |\x0a\x09pkg := self packageAt: packageName ifAbsent: [self error: 'Missing package: ', packageName].\x0a\x09pkg classes do: [:each |\x0a\x09\x09\x09self removeClass: each].\x0a\x09self deletePackage: packageName", messageSends: ["packageAt:ifAbsent:", "error:", ",", "do:", "removeClass:", "classes", "deletePackage:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "renamePackage:to:", category: 'packages', fn: function (packageName,newName){ var self=this; var pkg; return smalltalk.withContext(function($ctx1) { var $1; pkg=self._packageAt_ifAbsent_(packageName,(function(){ return smalltalk.withContext(function($ctx2) { return self._error_("Missing package: ".__comma(packageName)); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=self._packageAt_(newName); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._error_("Already exists a package called: ".__comma(newName)); }; _st(self._at_("packages"))._at_put_(newName,pkg); _st(pkg)._name_(newName); self._deletePackage_(packageName); return self}, function($ctx1) {$ctx1.fill(self,"renamePackage:to:",{packageName:packageName,newName:newName,pkg:pkg},smalltalk.Smalltalk)})}, args: ["packageName", "newName"], source: "renamePackage: packageName to: newName\x0a\x09\x22Rename a package.\x22\x0a\x0a\x09| pkg |\x0a\x09pkg := self packageAt: packageName ifAbsent: [self error: 'Missing package: ', packageName].\x0a\x09(self packageAt: newName) ifNotNil: [self error: 'Already exists a package called: ', newName].\x0a\x09(self at: 'packages') at: newName put: pkg.\x0a\x09pkg name: newName.\x0a\x09self deletePackage: packageName.", messageSends: ["packageAt:ifAbsent:", "error:", ",", "ifNotNil:", "packageAt:", "at:put:", "at:", "name:", "deletePackage:"], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "reservedWords", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.reservedWords; return self}, function($ctx1) {$ctx1.fill(self,"reservedWords",{},smalltalk.Smalltalk)})}, args: [], source: "reservedWords\x0a\x09\x22JavaScript reserved words\x22\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "version", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "0.12.0-pre"; }, function($ctx1) {$ctx1.fill(self,"version",{},smalltalk.Smalltalk)})}, args: [], source: "version\x0a\x09\x22Answer the version string of Amber\x22\x0a\x09\x0a\x09^ '0.12.0-pre'", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk); smalltalk.addMethod( smalltalk.method({ selector: "current", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return smalltalk; return self}, function($ctx1) {$ctx1.fill(self,"current",{},smalltalk.Smalltalk.klass)})}, args: [], source: "current\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Smalltalk.klass); smalltalk.addMethod( smalltalk.method({ selector: "do:displayingProgress:", category: '*Kernel-Infrastructure', fn: function (aBlock,aString){ var self=this; function $ProgressHandler(){return smalltalk.ProgressHandler||(typeof ProgressHandler=="undefined"?nil:ProgressHandler)} return smalltalk.withContext(function($ctx1) { _st(_st($ProgressHandler())._current())._do_on_displaying_(aBlock,self,aString); return self}, function($ctx1) {$ctx1.fill(self,"do:displayingProgress:",{aBlock:aBlock,aString:aString},smalltalk.SequenceableCollection)})}, args: ["aBlock", "aString"], source: "do: aBlock displayingProgress: aString\x0a\x09ProgressHandler current\x0a\x09\x09do: aBlock on: self displaying: aString", messageSends: ["do:on:displaying:", "current"], referencedClasses: ["ProgressHandler"] }), smalltalk.SequenceableCollection); smalltalk.addMethod( smalltalk.method({ selector: "asJavaScriptSelector", category: '*Kernel-Infrastructure', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._replace_with_("^([a-zA-Z0-9]*).*$","$1"); return $1; }, function($ctx1) {$ctx1.fill(self,"asJavaScriptSelector",{},smalltalk.String)})}, args: [], source: "asJavaScriptSelector\x0a\x09\x22Return first keyword of the selector, without trailing colon.\x22\x0a\x09^self replace: '^([a-zA-Z0-9]*).*$' with: '$1'", messageSends: ["replace:with:"], referencedClasses: [] }), smalltalk.String); }); define("amber_core/Kernel-Exceptions", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Exceptions'); smalltalk.packages["Kernel-Exceptions"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('Error', smalltalk.Object, ['messageText'], 'Kernel-Exceptions'); smalltalk.Error.comment="From the ANSI standard:\x0a\x0aThis protocol describes the behavior of instances of class `Error`.\x0aThese are used to represent error conditions that prevent the normal continuation of processing.\x0aActual error exceptions used by an application may be subclasses of this class.\x0aAs `Error` is explicitly specified to be subclassable, conforming implementations must implement its behavior in a non-fragile manner."; smalltalk.addMethod( smalltalk.method({ selector: "context", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.context; return self}, function($ctx1) {$ctx1.fill(self,"context",{},smalltalk.Error)})}, args: [], source: "context\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._messageText_("Errorclass: ".__comma(_st(self._class())._name())); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Error)})}, args: [], source: "initialize\x0a\x09self messageText: 'Errorclass: ', (self class name).", messageSends: ["messageText:", ",", "name", "class"], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "isSmalltalkError", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.smalltalkError === true; return self}, function($ctx1) {$ctx1.fill(self,"isSmalltalkError",{},smalltalk.Error)})}, args: [], source: "isSmalltalkError\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "jsStack", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self.stack; return self}, function($ctx1) {$ctx1.fill(self,"jsStack",{},smalltalk.Error)})}, args: [], source: "jsStack\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@messageText"]; return $1; }, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.Error)})}, args: [], source: "messageText\x0a\x09^messageText", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "messageText:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@messageText"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"messageText:",{aString:aString},smalltalk.Error)})}, args: ["aString"], source: "messageText: aString\x0a\x09messageText := aString", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "resignal", category: 'signaling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { throw(self); return self}, function($ctx1) {$ctx1.fill(self,"resignal",{},smalltalk.Error)})}, args: [], source: "resignal\x0a\x09\x22Resignal the receiver without changing its exception context\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "signal", category: 'signaling', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self.context = smalltalk.getThisContext(); self.smalltalkError = true; throw(self); return self}, function($ctx1) {$ctx1.fill(self,"signal",{},smalltalk.Error)})}, args: [], source: "signal\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "signal:", category: 'signaling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self._messageText_(aString); self._signal(); return self}, function($ctx1) {$ctx1.fill(self,"signal:",{aString:aString},smalltalk.Error)})}, args: ["aString"], source: "signal: aString\x0a\x09self messageText: aString.\x0a\x09self signal", messageSends: ["messageText:", "signal"], referencedClasses: [] }), smalltalk.Error); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "exception"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.Error.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'exception'", messageSends: [], referencedClasses: [] }), smalltalk.Error.klass); smalltalk.addMethod( smalltalk.method({ selector: "signal", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._new())._signal(); return $1; }, function($ctx1) {$ctx1.fill(self,"signal",{},smalltalk.Error.klass)})}, args: [], source: "signal\x0a\x09^self new signal", messageSends: ["signal", "new"], referencedClasses: [] }), smalltalk.Error.klass); smalltalk.addMethod( smalltalk.method({ selector: "signal:", category: 'instance creation', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._new())._signal_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"signal:",{aString:aString},smalltalk.Error.klass)})}, args: ["aString"], source: "signal: aString\x0a\x09\x09^self new\x0a\x09\x09signal: aString", messageSends: ["signal:", "new"], referencedClasses: [] }), smalltalk.Error.klass); smalltalk.addClass('JavaScriptException', smalltalk.Error, ['exception'], 'Kernel-Exceptions'); smalltalk.JavaScriptException.comment="A JavaScriptException is thrown when a non-Smalltalk exception occurs while in the Smalltalk stack.\x0aSee `boot.js` `inContext()` and `BlockClosure >> on:do:`"; smalltalk.addMethod( smalltalk.method({ selector: "context:", category: 'accessing', fn: function (aMethodContext){ var self=this; return smalltalk.withContext(function($ctx1) { self.context = aMethodContext; return self}, function($ctx1) {$ctx1.fill(self,"context:",{aMethodContext:aMethodContext},smalltalk.JavaScriptException)})}, args: ["aMethodContext"], source: "context: aMethodContext\x0a\x09\x22Set the context from the outside.\x0a\x09See boot.js `inContext()` exception handling\x22\x0a\x09\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.JavaScriptException); smalltalk.addMethod( smalltalk.method({ selector: "exception", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@exception"]; return $1; }, function($ctx1) {$ctx1.fill(self,"exception",{},smalltalk.JavaScriptException)})}, args: [], source: "exception\x0a\x09^ exception", messageSends: [], referencedClasses: [] }), smalltalk.JavaScriptException); smalltalk.addMethod( smalltalk.method({ selector: "exception:", category: 'accessing', fn: function (anException){ var self=this; return smalltalk.withContext(function($ctx1) { self["@exception"]=anException; return self}, function($ctx1) {$ctx1.fill(self,"exception:",{anException:anException},smalltalk.JavaScriptException)})}, args: ["anException"], source: "exception: anException\x0a\x09exception := anException", messageSends: [], referencedClasses: [] }), smalltalk.JavaScriptException); smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return 'JavaScript exception: ' + self["@exception"].toString(); return self}, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.JavaScriptException)})}, args: [], source: "messageText\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.JavaScriptException); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (anException){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._exception_(anException); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{anException:anException},smalltalk.JavaScriptException.klass)})}, args: ["anException"], source: "on: anException\x0a\x09^ self new\x0a\x09\x09exception: anException;\x0a\x09\x09yourself", messageSends: ["exception:", "new", "yourself"], referencedClasses: [] }), smalltalk.JavaScriptException.klass); smalltalk.addMethod( smalltalk.method({ selector: "on:context:", category: 'instance creation', fn: function (anException,aMethodContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._exception_(anException); _st($2)._context_(aMethodContext); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:context:",{anException:anException,aMethodContext:aMethodContext},smalltalk.JavaScriptException.klass)})}, args: ["anException", "aMethodContext"], source: "on: anException context: aMethodContext\x0a\x09^ self new\x0a\x09\x09exception: anException;\x0a\x09\x09context: aMethodContext;\x0a\x09\x09yourself", messageSends: ["exception:", "new", "context:", "yourself"], referencedClasses: [] }), smalltalk.JavaScriptException.klass); smalltalk.addClass('MessageNotUnderstood', smalltalk.Error, ['message', 'receiver'], 'Kernel-Exceptions'); smalltalk.MessageNotUnderstood.comment="This exception is provided to support `Object>>doesNotUnderstand:`."; smalltalk.addMethod( smalltalk.method({ selector: "message", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@message"]; return $1; }, function($ctx1) {$ctx1.fill(self,"message",{},smalltalk.MessageNotUnderstood)})}, args: [], source: "message\x0a\x09^message", messageSends: [], referencedClasses: [] }), smalltalk.MessageNotUnderstood); smalltalk.addMethod( smalltalk.method({ selector: "message:", category: 'accessing', fn: function (aMessage){ var self=this; return smalltalk.withContext(function($ctx1) { self["@message"]=aMessage; return self}, function($ctx1) {$ctx1.fill(self,"message:",{aMessage:aMessage},smalltalk.MessageNotUnderstood)})}, args: ["aMessage"], source: "message: aMessage\x0a\x09message := aMessage", messageSends: [], referencedClasses: [] }), smalltalk.MessageNotUnderstood); smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(self._receiver())._asString()).__comma(" does not understand #")).__comma(_st(self._message())._selector()); return $1; }, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.MessageNotUnderstood)})}, args: [], source: "messageText\x0a\x09^self receiver asString, ' does not understand #', self message selector", messageSends: [",", "selector", "message", "asString", "receiver"], referencedClasses: [] }), smalltalk.MessageNotUnderstood); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@receiver"]; return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.MessageNotUnderstood)})}, args: [], source: "receiver\x0a\x09^receiver", messageSends: [], referencedClasses: [] }), smalltalk.MessageNotUnderstood); smalltalk.addMethod( smalltalk.method({ selector: "receiver:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@receiver"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"receiver:",{anObject:anObject},smalltalk.MessageNotUnderstood)})}, args: ["anObject"], source: "receiver: anObject\x0a\x09receiver := anObject", messageSends: [], referencedClasses: [] }), smalltalk.MessageNotUnderstood); smalltalk.addClass('NonBooleanReceiver', smalltalk.Error, ['object'], 'Kernel-Exceptions'); smalltalk.NonBooleanReceiver.comment="NonBooleanReceiver exceptions may be thrown when executing inlined methods such as `#ifTrue:` with a non boolean receiver."; smalltalk.addMethod( smalltalk.method({ selector: "object", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@object"]; return $1; }, function($ctx1) {$ctx1.fill(self,"object",{},smalltalk.NonBooleanReceiver)})}, args: [], source: "object\x0a\x09^ object", messageSends: [], referencedClasses: [] }), smalltalk.NonBooleanReceiver); smalltalk.addMethod( smalltalk.method({ selector: "object:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@object"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"object:",{anObject:anObject},smalltalk.NonBooleanReceiver)})}, args: ["anObject"], source: "object: anObject\x0a\x09object := anObject", messageSends: [], referencedClasses: [] }), smalltalk.NonBooleanReceiver); smalltalk.addClass('ErrorHandler', smalltalk.Object, [], 'Kernel-Exceptions'); smalltalk.ErrorHandler.comment="I am used to manage Smalltalk errors.\x0aSee `boot.js` `handleError()` function.\x0a\x0aSubclasses can register themselves as the current handler with\x0a`ErrorHandler class >> register`.\x0a\x0aSubclasses may override `#handleError:` to perform an action on the thrown exception.\x0aThe default behavior is to log the error and the context stack to the JavaScript console."; smalltalk.addMethod( smalltalk.method({ selector: "handleError:", category: 'error handling', fn: function (anError){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anError)._context(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._logErrorContext_(_st(anError)._context()); }; self._logError_(anError); return self}, function($ctx1) {$ctx1.fill(self,"handleError:",{anError:anError},smalltalk.ErrorHandler)})}, args: ["anError"], source: "handleError: anError\x0a\x09anError context ifNotNil: [self logErrorContext: anError context].\x0a\x09self logError: anError", messageSends: ["ifNotNil:", "logErrorContext:", "context", "logError:"], referencedClasses: [] }), smalltalk.ErrorHandler); smalltalk.addMethod( smalltalk.method({ selector: "log:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(console)._log_(aString); return self}, function($ctx1) {$ctx1.fill(self,"log:",{aString:aString},smalltalk.ErrorHandler)})}, args: ["aString"], source: "log: aString\x0a\x09console log: aString", messageSends: ["log:"], referencedClasses: [] }), smalltalk.ErrorHandler); smalltalk.addMethod( smalltalk.method({ selector: "logContext:", category: 'private', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aContext)._home(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._logContext_(_st(aContext)._home()); }; self._log_(_st(aContext)._asString()); return self}, function($ctx1) {$ctx1.fill(self,"logContext:",{aContext:aContext},smalltalk.ErrorHandler)})}, args: ["aContext"], source: "logContext: aContext\x0a\x09aContext home ifNotNil: [\x0a\x09\x09self logContext: aContext home].\x0a\x09self log: aContext asString", messageSends: ["ifNotNil:", "logContext:", "home", "log:", "asString"], referencedClasses: [] }), smalltalk.ErrorHandler); smalltalk.addMethod( smalltalk.method({ selector: "logError:", category: 'private', fn: function (anError){ var self=this; return smalltalk.withContext(function($ctx1) { self._log_(_st(anError)._messageText()); return self}, function($ctx1) {$ctx1.fill(self,"logError:",{anError:anError},smalltalk.ErrorHandler)})}, args: ["anError"], source: "logError: anError\x0a\x09self log: anError messageText", messageSends: ["log:", "messageText"], referencedClasses: [] }), smalltalk.ErrorHandler); smalltalk.addMethod( smalltalk.method({ selector: "logErrorContext:", category: 'private', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aContext; if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { $2=_st(aContext)._home(); if(($receiver = $2) == nil || $receiver == undefined){ $2; } else { self._logContext_(_st(aContext)._home()); }; }; return self}, function($ctx1) {$ctx1.fill(self,"logErrorContext:",{aContext:aContext},smalltalk.ErrorHandler)})}, args: ["aContext"], source: "logErrorContext: aContext\x0a\x09aContext ifNotNil: [\x0a\x09\x09aContext home ifNotNil: [\x0a\x09\x09\x09self logContext: aContext home]]", messageSends: ["ifNotNil:", "logContext:", "home"], referencedClasses: [] }), smalltalk.ErrorHandler); smalltalk.ErrorHandler.klass.iVarNames = ['current']; smalltalk.addMethod( smalltalk.method({ selector: "current", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@current"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@current"]=self._new(); $1=self["@current"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"current",{},smalltalk.ErrorHandler.klass)})}, args: [], source: "current\x0a\x09^current ifNil: [current := self new]", messageSends: ["ifNil:", "new"], referencedClasses: [] }), smalltalk.ErrorHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._register(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ErrorHandler.klass)})}, args: [], source: "initialize\x0a\x09self register", messageSends: ["register"], referencedClasses: [] }), smalltalk.ErrorHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "register", category: 'initialization', fn: function (){ var self=this; function $ErrorHandler(){return smalltalk.ErrorHandler||(typeof ErrorHandler=="undefined"?nil:ErrorHandler)} return smalltalk.withContext(function($ctx1) { _st($ErrorHandler())._setCurrent_(self._new()); return self}, function($ctx1) {$ctx1.fill(self,"register",{},smalltalk.ErrorHandler.klass)})}, args: [], source: "register\x0a\x09ErrorHandler setCurrent: self new", messageSends: ["setCurrent:", "new"], referencedClasses: ["ErrorHandler"] }), smalltalk.ErrorHandler.klass); smalltalk.addMethod( smalltalk.method({ selector: "setCurrent:", category: 'accessing', fn: function (anHandler){ var self=this; return smalltalk.withContext(function($ctx1) { self["@current"]=anHandler; return self}, function($ctx1) {$ctx1.fill(self,"setCurrent:",{anHandler:anHandler},smalltalk.ErrorHandler.klass)})}, args: ["anHandler"], source: "setCurrent: anHandler\x0a\x09current := anHandler", messageSends: [], referencedClasses: [] }), smalltalk.ErrorHandler.klass); }); define("amber_core/Kernel-Transcript", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Transcript'); smalltalk.packages["Kernel-Transcript"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('ConsoleTranscript', smalltalk.Object, ['textarea'], 'Kernel-Transcript'); smalltalk.ConsoleTranscript.comment="I am a specific transcript emitting to the JavaScript console.\x0a\x0aIf no other transcript is registered, I am the default."; smalltalk.addMethod( smalltalk.method({ selector: "clear", category: 'printing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"clear",{},smalltalk.ConsoleTranscript)})}, args: [], source: "clear\x0a\x09\x22no op\x22", messageSends: [], referencedClasses: [] }), smalltalk.ConsoleTranscript); smalltalk.addMethod( smalltalk.method({ selector: "cr", category: 'printing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"cr",{},smalltalk.ConsoleTranscript)})}, args: [], source: "cr\x0a\x09\x22no op\x22", messageSends: [], referencedClasses: [] }), smalltalk.ConsoleTranscript); smalltalk.addMethod( smalltalk.method({ selector: "open", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"open",{},smalltalk.ConsoleTranscript)})}, args: [], source: "open", messageSends: [], referencedClasses: [] }), smalltalk.ConsoleTranscript); smalltalk.addMethod( smalltalk.method({ selector: "show:", category: 'printing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { console.log(String(_st(anObject)._asString())); return self}, function($ctx1) {$ctx1.fill(self,"show:",{anObject:anObject},smalltalk.ConsoleTranscript)})}, args: ["anObject"], source: "show: anObject\x0a\x22Smalltalk objects should have no trouble displaying themselves on the Transcript; Javascript objects don't know how, so must be wrapped in a JSObectProxy.\x22\x0a", messageSends: [], referencedClasses: [] }), smalltalk.ConsoleTranscript); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $Transcript(){return smalltalk.Transcript||(typeof Transcript=="undefined"?nil:Transcript)} return smalltalk.withContext(function($ctx1) { _st($Transcript())._register_(self._new()); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ConsoleTranscript.klass)})}, args: [], source: "initialize\x0a\x09Transcript register: self new", messageSends: ["register:", "new"], referencedClasses: ["Transcript"] }), smalltalk.ConsoleTranscript.klass); smalltalk.addClass('Transcript', smalltalk.Object, [], 'Kernel-Transcript'); smalltalk.Transcript.comment="I am a facade for Transcript actions.\x0a\x0aI delegate actions to the currently registered transcript.\x0a\x0a## API\x0a\x0a Transcript \x0a show: 'hello world';\x0a cr;\x0a show: anObject."; smalltalk.Transcript.klass.iVarNames = ['current']; smalltalk.addMethod( smalltalk.method({ selector: "clear", category: 'printing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._current())._clear(); return self}, function($ctx1) {$ctx1.fill(self,"clear",{},smalltalk.Transcript.klass)})}, args: [], source: "clear\x0a\x09self current clear", messageSends: ["clear", "current"], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "cr", category: 'printing', fn: function (){ var self=this; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { _st(self._current())._show_(_st($String())._cr()); return self}, function($ctx1) {$ctx1.fill(self,"cr",{},smalltalk.Transcript.klass)})}, args: [], source: "cr\x0a\x09self current show: String cr", messageSends: ["show:", "cr", "current"], referencedClasses: ["String"] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "current", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@current"]; return $1; }, function($ctx1) {$ctx1.fill(self,"current",{},smalltalk.Transcript.klass)})}, args: [], source: "current\x0a\x09^current", messageSends: [], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "inspect:", category: 'printing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self._show_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"inspect:",{anObject:anObject},smalltalk.Transcript.klass)})}, args: ["anObject"], source: "inspect: anObject\x0a\x09self show: anObject", messageSends: ["show:"], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "new", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldNotImplement(); return self}, function($ctx1) {$ctx1.fill(self,"new",{},smalltalk.Transcript.klass)})}, args: [], source: "new\x0a\x09self shouldNotImplement", messageSends: ["shouldNotImplement"], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "open", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._current())._open(); return self}, function($ctx1) {$ctx1.fill(self,"open",{},smalltalk.Transcript.klass)})}, args: [], source: "open\x0a\x09self current open", messageSends: ["open", "current"], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "register:", category: 'instance creation', fn: function (aTranscript){ var self=this; return smalltalk.withContext(function($ctx1) { self["@current"]=aTranscript; return self}, function($ctx1) {$ctx1.fill(self,"register:",{aTranscript:aTranscript},smalltalk.Transcript.klass)})}, args: ["aTranscript"], source: "register: aTranscript\x0a\x09current := aTranscript", messageSends: [], referencedClasses: [] }), smalltalk.Transcript.klass); smalltalk.addMethod( smalltalk.method({ selector: "show:", category: 'printing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._current())._show_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"show:",{anObject:anObject},smalltalk.Transcript.klass)})}, args: ["anObject"], source: "show: anObject\x0a\x09self current show: anObject", messageSends: ["show:", "current"], referencedClasses: [] }), smalltalk.Transcript.klass); }); define("amber_core/Kernel-Announcements", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Kernel-Announcements'); smalltalk.packages["Kernel-Announcements"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('AnnouncementSubscription', smalltalk.Object, ['valuable', 'announcementClass'], 'Kernel-Announcements'); smalltalk.AnnouncementSubscription.comment="I am a single entry in a subscription registry of an `Announcer`.\x0aSeveral subscriptions by the same object is possible."; smalltalk.addMethod( smalltalk.method({ selector: "announcementClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@announcementClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"announcementClass",{},smalltalk.AnnouncementSubscription)})}, args: [], source: "announcementClass\x0a\x09^ announcementClass", messageSends: [], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "announcementClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@announcementClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"announcementClass:",{aClass:aClass},smalltalk.AnnouncementSubscription)})}, args: ["aClass"], source: "announcementClass: aClass\x0a\x09announcementClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "block", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._deprecatedAPI(); $1=self._valuable(); return $1; }, function($ctx1) {$ctx1.fill(self,"block",{},smalltalk.AnnouncementSubscription)})}, args: [], source: "block\x0a\x09\x22Use #valuable instead\x22\x0a\x09\x0a\x09self deprecatedAPI.\x0a\x09^ self valuable", messageSends: ["deprecatedAPI", "valuable"], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "block:", category: 'accessing', fn: function (aValuable){ var self=this; return smalltalk.withContext(function($ctx1) { self._deprecatedAPI(); self._valuable_(aValuable); return self}, function($ctx1) {$ctx1.fill(self,"block:",{aValuable:aValuable},smalltalk.AnnouncementSubscription)})}, args: ["aValuable"], source: "block: aValuable\x0a\x09\x22Use #valuable instead\x22\x0a\x09\x0a\x09self deprecatedAPI.\x0a\x09self valuable: aValuable", messageSends: ["deprecatedAPI", "valuable:"], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "deliver:", category: 'announcing', fn: function (anAnnouncement){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._handlesAnnouncement_(anAnnouncement); if(smalltalk.assert($1)){ _st(self._valuable())._value_(anAnnouncement); }; return self}, function($ctx1) {$ctx1.fill(self,"deliver:",{anAnnouncement:anAnnouncement},smalltalk.AnnouncementSubscription)})}, args: ["anAnnouncement"], source: "deliver: anAnnouncement\x0a\x09(self handlesAnnouncement: anAnnouncement)\x0a\x09\x09ifTrue: [self valuable value: anAnnouncement]", messageSends: ["ifTrue:", "value:", "valuable", "handlesAnnouncement:"], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "handlesAnnouncement:", category: 'announcing', fn: function (anAnnouncement){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st($Smalltalk())._current())._at_(_st(self._announcementClass())._name()); if(($receiver = $2) == nil || $receiver == undefined){ return false; } else { var class_; class_=$receiver; $1=_st(class_)._includesBehavior_(_st(_st($Smalltalk())._current())._at_(_st(_st(_st(anAnnouncement)._class())._theNonMetaClass())._name())); }; return $1; }, function($ctx1) {$ctx1.fill(self,"handlesAnnouncement:",{anAnnouncement:anAnnouncement},smalltalk.AnnouncementSubscription)})}, args: ["anAnnouncement"], source: "handlesAnnouncement: anAnnouncement\x0a\x09\x22anAnnouncement might be announced from within another Amber environment\x22\x0a\x09\x0a\x09^ (Smalltalk current at: self announcementClass name)\x0a\x09\x09ifNil: [ ^ false ]\x0a\x09\x09ifNotNil: [ :class |\x0a\x09\x09class includesBehavior: (Smalltalk current at: anAnnouncement class theNonMetaClass name) ]", messageSends: ["ifNil:ifNotNil:", "includesBehavior:", "at:", "name", "theNonMetaClass", "class", "current", "announcementClass"], referencedClasses: ["Smalltalk"] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._valuable())._receiver(); return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.AnnouncementSubscription)})}, args: [], source: "receiver\x0a\x09^ self valuable receiver", messageSends: ["receiver", "valuable"], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "valuable", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@valuable"]; return $1; }, function($ctx1) {$ctx1.fill(self,"valuable",{},smalltalk.AnnouncementSubscription)})}, args: [], source: "valuable\x0a\x09^ valuable", messageSends: [], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addMethod( smalltalk.method({ selector: "valuable:", category: 'accessing', fn: function (aValuable){ var self=this; return smalltalk.withContext(function($ctx1) { self["@valuable"]=aValuable; return self}, function($ctx1) {$ctx1.fill(self,"valuable:",{aValuable:aValuable},smalltalk.AnnouncementSubscription)})}, args: ["aValuable"], source: "valuable: aValuable\x0a\x09valuable := aValuable", messageSends: [], referencedClasses: [] }), smalltalk.AnnouncementSubscription); smalltalk.addClass('Announcer', smalltalk.Object, ['registry', 'subscriptions'], 'Kernel-Announcements'); smalltalk.Announcer.comment="I hold annoncement subscriptions (instances of `AnnouncementSubscription`) in a private registry.\x0aI announce (trigger) announces, which are then dispatched to all subscriptions.\x0a\x0aThe code is based on the announcements as [described by Vassili Bykov](http://www.cincomsmalltalk.com/userblogs/vbykov/blogView?searchCategory=Announcements%20Framework).\x0a\x0a## API\x0a\x0aUse `#announce:` to trigger an announcement.\x0a\x0aUse `#on:do:` or `#on:send:to:` to register subscriptions.\x0a\x0aWhen using `#on:send:to:`, unregistration can be done with `#unregister:`.\x0a\x0a## Usage example:\x0a\x0a SystemAnnouncer current\x0a on: ClassAdded\x0a do: [ :ann | window alert: ann theClass name, ' added' ]."; smalltalk.addMethod( smalltalk.method({ selector: "announce:", category: 'announcing', fn: function (anAnnouncement){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@subscriptions"])._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._deliver_(anAnnouncement); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"announce:",{anAnnouncement:anAnnouncement},smalltalk.Announcer)})}, args: ["anAnnouncement"], source: "announce: anAnnouncement\x0a\x09subscriptions do: [ :each |\x0a\x09\x09each deliver: anAnnouncement ]", messageSends: ["do:", "deliver:"], referencedClasses: [] }), smalltalk.Announcer); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { smalltalk.Announcer.superclass.fn.prototype._initialize.apply(_st(self), []); self["@subscriptions"]=_st($OrderedCollection())._new(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Announcer)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09subscriptions := OrderedCollection new", messageSends: ["initialize", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.Announcer); smalltalk.addMethod( smalltalk.method({ selector: "on:do:", category: 'subscribing', fn: function (aClass,aBlock){ var self=this; function $AnnouncementSubscription(){return smalltalk.AnnouncementSubscription||(typeof AnnouncementSubscription=="undefined"?nil:AnnouncementSubscription)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st($AnnouncementSubscription())._new(); _st($1)._valuable_(aBlock); _st($1)._announcementClass_(aClass); $2=_st($1)._yourself(); _st(self["@subscriptions"])._add_($2); return self}, function($ctx1) {$ctx1.fill(self,"on:do:",{aClass:aClass,aBlock:aBlock},smalltalk.Announcer)})}, args: ["aClass", "aBlock"], source: "on: aClass do: aBlock\x0a\x09subscriptions add: (AnnouncementSubscription new\x0a\x09\x09valuable: aBlock;\x0a\x09\x09announcementClass: aClass;\x0a\x09\x09yourself)", messageSends: ["add:", "valuable:", "new", "announcementClass:", "yourself"], referencedClasses: ["AnnouncementSubscription"] }), smalltalk.Announcer); smalltalk.addMethod( smalltalk.method({ selector: "on:send:to:", category: 'subscribing', fn: function (aClass,aSelector,anObject){ var self=this; function $MessageSend(){return smalltalk.MessageSend||(typeof MessageSend=="undefined"?nil:MessageSend)} function $AnnouncementSubscription(){return smalltalk.AnnouncementSubscription||(typeof AnnouncementSubscription=="undefined"?nil:AnnouncementSubscription)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=_st($AnnouncementSubscription())._new(); $2=_st($MessageSend())._new(); _st($2)._receiver_(anObject); _st($2)._selector_(aSelector); $3=_st($2)._yourself(); _st($1)._valuable_($3); _st($1)._announcementClass_(aClass); $4=_st($1)._yourself(); _st(self["@subscriptions"])._add_($4); return self}, function($ctx1) {$ctx1.fill(self,"on:send:to:",{aClass:aClass,aSelector:aSelector,anObject:anObject},smalltalk.Announcer)})}, args: ["aClass", "aSelector", "anObject"], source: "on: aClass send: aSelector to: anObject\x0a\x09subscriptions add: (AnnouncementSubscription new\x0a\x09\x09valuable: (MessageSend new\x0a\x09\x09\x09receiver: anObject;\x0a\x09\x09\x09selector: aSelector;\x0a\x09\x09\x09yourself);\x0a\x09\x09announcementClass: aClass;\x0a\x09\x09yourself)", messageSends: ["add:", "valuable:", "receiver:", "new", "selector:", "yourself", "announcementClass:"], referencedClasses: ["MessageSend", "AnnouncementSubscription"] }), smalltalk.Announcer); smalltalk.addMethod( smalltalk.method({ selector: "unsubscribe:", category: 'subscribing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@subscriptions"]=_st(self["@subscriptions"])._reject_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._receiver()).__eq(anObject); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"unsubscribe:",{anObject:anObject},smalltalk.Announcer)})}, args: ["anObject"], source: "unsubscribe: anObject\x0a\x09subscriptions := subscriptions reject: [ :each |\x0a\x09\x09each receiver = anObject ]", messageSends: ["reject:", "=", "receiver"], referencedClasses: [] }), smalltalk.Announcer); smalltalk.addClass('SystemAnnouncer', smalltalk.Announcer, [], 'Kernel-Announcements'); smalltalk.SystemAnnouncer.comment="My unique instance is the global announcer handling all Amber system-related announces.\x0a\x0a## API\x0a\x0aAccess to the unique instance is done via `#current`"; smalltalk.SystemAnnouncer.klass.iVarNames = ['current']; smalltalk.addMethod( smalltalk.method({ selector: "current", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@current"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@current"]=smalltalk.SystemAnnouncer.klass.superclass.fn.prototype._new.apply(_st(self), []); $1=self["@current"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"current",{},smalltalk.SystemAnnouncer.klass)})}, args: [], source: "current\x0a\x09^ current ifNil: [ current := super new ]", messageSends: ["ifNil:", "new"], referencedClasses: [] }), smalltalk.SystemAnnouncer.klass); smalltalk.addMethod( smalltalk.method({ selector: "new", category: 'instance creation', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldNotImplement(); return self}, function($ctx1) {$ctx1.fill(self,"new",{},smalltalk.SystemAnnouncer.klass)})}, args: [], source: "new\x0a\x09self shouldNotImplement", messageSends: ["shouldNotImplement"], referencedClasses: [] }), smalltalk.SystemAnnouncer.klass); smalltalk.addClass('SystemAnnouncement', smalltalk.Object, ['theClass'], 'Kernel-Announcements'); smalltalk.SystemAnnouncement.comment="I am the superclass of all system announcements"; smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.SystemAnnouncement)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.SystemAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.SystemAnnouncement)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.SystemAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "heliosClass", category: 'helios', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "announcement"; }, function($ctx1) {$ctx1.fill(self,"heliosClass",{},smalltalk.SystemAnnouncement.klass)})}, args: [], source: "heliosClass\x0a\x09^ 'announcement'", messageSends: [], referencedClasses: [] }), smalltalk.SystemAnnouncement.klass); smalltalk.addClass('ClassAnnouncement', smalltalk.SystemAnnouncement, ['theClass'], 'Kernel-Announcements'); smalltalk.ClassAnnouncement.comment="I am the abstract superclass of class-related announcements."; smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.ClassAnnouncement)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.ClassAnnouncement)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassAnnouncement); smalltalk.addClass('ClassAdded', smalltalk.ClassAnnouncement, [], 'Kernel-Announcements'); smalltalk.ClassAdded.comment="I am emitted when a class is added to the system.\x0aSee ClassBuilder >> #addSubclassOf:... methods"; smalltalk.addClass('ClassCommentChanged', smalltalk.ClassAnnouncement, [], 'Kernel-Announcements'); smalltalk.ClassCommentChanged.comment="I am emitted when the comment of a class changes. (Behavior >> #comment)"; smalltalk.addClass('ClassDefinitionChanged', smalltalk.ClassAnnouncement, [], 'Kernel-Announcements'); smalltalk.ClassDefinitionChanged.comment="I am emitted when the definition of a class changes.\x0aSee ClassBuilder >> #class:instanceVariableNames:"; smalltalk.addClass('ClassMigrated', smalltalk.ClassAnnouncement, ['oldClass'], 'Kernel-Announcements'); smalltalk.ClassMigrated.comment="I am emitted when a class is migrated."; smalltalk.addMethod( smalltalk.method({ selector: "oldClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@oldClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"oldClass",{},smalltalk.ClassMigrated)})}, args: [], source: "oldClass\x0a\x09^ oldClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassMigrated); smalltalk.addMethod( smalltalk.method({ selector: "oldClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@oldClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"oldClass:",{aClass:aClass},smalltalk.ClassMigrated)})}, args: ["aClass"], source: "oldClass: aClass\x0a\x09oldClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.ClassMigrated); smalltalk.addClass('ClassMoved', smalltalk.ClassAnnouncement, ['oldPackage'], 'Kernel-Announcements'); smalltalk.ClassMoved.comment="I am emitted when a class is moved from one package to another."; smalltalk.addMethod( smalltalk.method({ selector: "oldPackage", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@oldPackage"]; return $1; }, function($ctx1) {$ctx1.fill(self,"oldPackage",{},smalltalk.ClassMoved)})}, args: [], source: "oldPackage\x0a\x09^ oldPackage", messageSends: [], referencedClasses: [] }), smalltalk.ClassMoved); smalltalk.addMethod( smalltalk.method({ selector: "oldPackage:", category: 'accessing', fn: function (aPackage){ var self=this; return smalltalk.withContext(function($ctx1) { self["@oldPackage"]=aPackage; return self}, function($ctx1) {$ctx1.fill(self,"oldPackage:",{aPackage:aPackage},smalltalk.ClassMoved)})}, args: ["aPackage"], source: "oldPackage: aPackage\x0a\x09oldPackage := aPackage", messageSends: [], referencedClasses: [] }), smalltalk.ClassMoved); smalltalk.addClass('ClassRemoved', smalltalk.ClassAnnouncement, [], 'Kernel-Announcements'); smalltalk.ClassRemoved.comment="I am emitted when a class is removed.\x0aSee Smalltalk >> #removeClass:"; smalltalk.addClass('ClassRenamed', smalltalk.ClassAnnouncement, [], 'Kernel-Announcements'); smalltalk.ClassRenamed.comment="I am emitted when a class is renamed.\x0aSee ClassBuilder >> #renameClass:to:"; smalltalk.addClass('MethodAnnouncement', smalltalk.SystemAnnouncement, ['method'], 'Kernel-Announcements'); smalltalk.MethodAnnouncement.comment="I am the abstract superclass of method-related announcements."; smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@method"]; return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.MethodAnnouncement)})}, args: [], source: "method\x0a\x09^ method", messageSends: [], referencedClasses: [] }), smalltalk.MethodAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "method:", category: 'accessing', fn: function (aCompiledMethod){ var self=this; return smalltalk.withContext(function($ctx1) { self["@method"]=aCompiledMethod; return self}, function($ctx1) {$ctx1.fill(self,"method:",{aCompiledMethod:aCompiledMethod},smalltalk.MethodAnnouncement)})}, args: ["aCompiledMethod"], source: "method: aCompiledMethod\x0a\x09method := aCompiledMethod", messageSends: [], referencedClasses: [] }), smalltalk.MethodAnnouncement); smalltalk.addClass('MethodAdded', smalltalk.MethodAnnouncement, [], 'Kernel-Announcements'); smalltalk.MethodAdded.comment="I am emitted when a `CompiledMethod` is added to a class."; smalltalk.addClass('MethodModified', smalltalk.MethodAnnouncement, ['oldMethod'], 'Kernel-Announcements'); smalltalk.MethodModified.comment="I am emitted when a `CompiledMethod` is modified (a new method is installed). I hold a reference to the old method being replaced."; smalltalk.addMethod( smalltalk.method({ selector: "oldMethod", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@oldMethod"]; return $1; }, function($ctx1) {$ctx1.fill(self,"oldMethod",{},smalltalk.MethodModified)})}, args: [], source: "oldMethod\x0a\x09^ oldMethod", messageSends: [], referencedClasses: [] }), smalltalk.MethodModified); smalltalk.addMethod( smalltalk.method({ selector: "oldMethod:", category: 'accessing', fn: function (aMethod){ var self=this; return smalltalk.withContext(function($ctx1) { self["@oldMethod"]=aMethod; return self}, function($ctx1) {$ctx1.fill(self,"oldMethod:",{aMethod:aMethod},smalltalk.MethodModified)})}, args: ["aMethod"], source: "oldMethod: aMethod\x0a\x09oldMethod := aMethod", messageSends: [], referencedClasses: [] }), smalltalk.MethodModified); smalltalk.addClass('MethodMoved', smalltalk.MethodAnnouncement, ['oldProtocol'], 'Kernel-Announcements'); smalltalk.MethodMoved.comment="I am emitted when a `CompiledMethod` is moved to another protocol. I hold a refernce to the old protocol of the method."; smalltalk.addMethod( smalltalk.method({ selector: "oldProtocol", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@oldProtocol"]; return $1; }, function($ctx1) {$ctx1.fill(self,"oldProtocol",{},smalltalk.MethodMoved)})}, args: [], source: "oldProtocol\x0a\x09^ oldProtocol", messageSends: [], referencedClasses: [] }), smalltalk.MethodMoved); smalltalk.addMethod( smalltalk.method({ selector: "oldProtocol:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@oldProtocol"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"oldProtocol:",{aString:aString},smalltalk.MethodMoved)})}, args: ["aString"], source: "oldProtocol: aString\x0a\x09oldProtocol := aString", messageSends: [], referencedClasses: [] }), smalltalk.MethodMoved); smalltalk.addClass('MethodRemoved', smalltalk.MethodAnnouncement, [], 'Kernel-Announcements'); smalltalk.MethodRemoved.comment="I am emitted when a `CompiledMethod` is removed from a class."; smalltalk.addClass('PackageAnnouncement', smalltalk.SystemAnnouncement, ['package'], 'Kernel-Announcements'); smalltalk.PackageAnnouncement.comment="I am the abstract superclass of package-related announcements."; smalltalk.addMethod( smalltalk.method({ selector: "package", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@package"]; return $1; }, function($ctx1) {$ctx1.fill(self,"package",{},smalltalk.PackageAnnouncement)})}, args: [], source: "package\x0a\x09^ package", messageSends: [], referencedClasses: [] }), smalltalk.PackageAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "package:", category: 'accessing', fn: function (aPackage){ var self=this; return smalltalk.withContext(function($ctx1) { self["@package"]=aPackage; return self}, function($ctx1) {$ctx1.fill(self,"package:",{aPackage:aPackage},smalltalk.PackageAnnouncement)})}, args: ["aPackage"], source: "package: aPackage\x0a\x09package := aPackage", messageSends: [], referencedClasses: [] }), smalltalk.PackageAnnouncement); smalltalk.addClass('PackageAdded', smalltalk.PackageAnnouncement, [], 'Kernel-Announcements'); smalltalk.PackageAdded.comment="I am emitted when a `Package` is added to the system."; smalltalk.addClass('PackageRemoved', smalltalk.PackageAnnouncement, [], 'Kernel-Announcements'); smalltalk.PackageRemoved.comment="I am emitted when a `Package` is removed from the system."; smalltalk.addClass('ProtocolAnnouncement', smalltalk.SystemAnnouncement, ['theClass', 'protocol'], 'Kernel-Announcements'); smalltalk.ProtocolAnnouncement.comment="I am the abstract superclass of protocol-related announcements."; smalltalk.addMethod( smalltalk.method({ selector: "protocol", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@protocol"]; return $1; }, function($ctx1) {$ctx1.fill(self,"protocol",{},smalltalk.ProtocolAnnouncement)})}, args: [], source: "protocol\x0a\x09^ protocol", messageSends: [], referencedClasses: [] }), smalltalk.ProtocolAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "protocol:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@protocol"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"protocol:",{aString:aString},smalltalk.ProtocolAnnouncement)})}, args: ["aString"], source: "protocol: aString\x0a\x09protocol := aString", messageSends: [], referencedClasses: [] }), smalltalk.ProtocolAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.ProtocolAnnouncement)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.ProtocolAnnouncement); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.ProtocolAnnouncement)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.ProtocolAnnouncement); smalltalk.addClass('ProtocolAdded', smalltalk.ProtocolAnnouncement, [], 'Kernel-Announcements'); smalltalk.ProtocolAdded.comment="I am emitted when a protocol is added to a class."; smalltalk.addClass('ProtocolRemoved', smalltalk.ProtocolAnnouncement, [], 'Kernel-Announcements'); smalltalk.ProtocolRemoved.comment="I am emitted when a protocol is removed from a class."; }); define("amber_core/Compiler-Exceptions", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Exceptions"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-Exceptions'); smalltalk.packages["Compiler-Exceptions"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('CompilerError', smalltalk.Error, [], 'Compiler-Exceptions'); smalltalk.CompilerError.comment="I am the common superclass of all compiling errors."; smalltalk.addClass('ParseError', smalltalk.CompilerError, [], 'Compiler-Exceptions'); smalltalk.ParseError.comment="Instance of ParseError are signaled on any parsing error.\x0aSee `Smalltalk >> #parse:`"; smalltalk.addClass('SemanticError', smalltalk.CompilerError, [], 'Compiler-Exceptions'); smalltalk.SemanticError.comment="I represent an abstract semantic error thrown by the SemanticAnalyzer.\x0aSemantic errors can be unknown variable errors, etc.\x0aSee my subclasses for concrete errors.\x0a\x0aThe IDE should catch instances of Semantic error to deal with them when compiling"; smalltalk.addClass('InliningError', smalltalk.SemanticError, [], 'Compiler-Exceptions'); smalltalk.InliningError.comment="Instances of InliningError are signaled when using an `InliningCodeGenerator`in a `Compiler`."; smalltalk.addClass('InvalidAssignmentError', smalltalk.SemanticError, ['variableName'], 'Compiler-Exceptions'); smalltalk.InvalidAssignmentError.comment="I get signaled when a pseudo variable gets assigned."; smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=" Invalid assignment to variable: ".__comma(self._variableName()); return $1; }, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.InvalidAssignmentError)})}, args: [], source: "messageText\x0a\x09^ ' Invalid assignment to variable: ', self variableName", messageSends: [",", "variableName"], referencedClasses: [] }), smalltalk.InvalidAssignmentError); smalltalk.addMethod( smalltalk.method({ selector: "variableName", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@variableName"]; return $1; }, function($ctx1) {$ctx1.fill(self,"variableName",{},smalltalk.InvalidAssignmentError)})}, args: [], source: "variableName\x0a\x09^ variableName", messageSends: [], referencedClasses: [] }), smalltalk.InvalidAssignmentError); smalltalk.addMethod( smalltalk.method({ selector: "variableName:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@variableName"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"variableName:",{aString:aString},smalltalk.InvalidAssignmentError)})}, args: ["aString"], source: "variableName: aString\x0a\x09variableName := aString", messageSends: [], referencedClasses: [] }), smalltalk.InvalidAssignmentError); smalltalk.addClass('ShadowingVariableError', smalltalk.SemanticError, ['variableName'], 'Compiler-Exceptions'); smalltalk.ShadowingVariableError.comment="I get signaled when a variable in a block or method scope shadows a variable of the same name in an outer scope."; smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("Variable shadowing error: ".__comma(self._variableName())).__comma(" is already defined"); return $1; }, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.ShadowingVariableError)})}, args: [], source: "messageText\x0a\x09^ 'Variable shadowing error: ', self variableName, ' is already defined'", messageSends: [",", "variableName"], referencedClasses: [] }), smalltalk.ShadowingVariableError); smalltalk.addMethod( smalltalk.method({ selector: "variableName", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@variableName"]; return $1; }, function($ctx1) {$ctx1.fill(self,"variableName",{},smalltalk.ShadowingVariableError)})}, args: [], source: "variableName\x0a\x09^ variableName", messageSends: [], referencedClasses: [] }), smalltalk.ShadowingVariableError); smalltalk.addMethod( smalltalk.method({ selector: "variableName:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@variableName"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"variableName:",{aString:aString},smalltalk.ShadowingVariableError)})}, args: ["aString"], source: "variableName: aString\x0a\x09variableName := aString", messageSends: [], referencedClasses: [] }), smalltalk.ShadowingVariableError); smalltalk.addClass('UnknownVariableError', smalltalk.SemanticError, ['variableName'], 'Compiler-Exceptions'); smalltalk.UnknownVariableError.comment="I get signaled when a variable is not defined.\x0aThe default behavior is to allow it, as this is how Amber currently is able to seamlessly send messages to JavaScript objects."; smalltalk.addMethod( smalltalk.method({ selector: "messageText", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("Unknown Variable error: ".__comma(self._variableName())).__comma(" is not defined"); return $1; }, function($ctx1) {$ctx1.fill(self,"messageText",{},smalltalk.UnknownVariableError)})}, args: [], source: "messageText\x0a\x09^ 'Unknown Variable error: ', self variableName, ' is not defined'", messageSends: [",", "variableName"], referencedClasses: [] }), smalltalk.UnknownVariableError); smalltalk.addMethod( smalltalk.method({ selector: "variableName", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@variableName"]; return $1; }, function($ctx1) {$ctx1.fill(self,"variableName",{},smalltalk.UnknownVariableError)})}, args: [], source: "variableName\x0a\x09^ variableName", messageSends: [], referencedClasses: [] }), smalltalk.UnknownVariableError); smalltalk.addMethod( smalltalk.method({ selector: "variableName:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@variableName"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"variableName:",{aString:aString},smalltalk.UnknownVariableError)})}, args: ["aString"], source: "variableName: aString\x0a\x09variableName := aString", messageSends: [], referencedClasses: [] }), smalltalk.UnknownVariableError); smalltalk.addClass('RethrowErrorHandler', smalltalk.ErrorHandler, [], 'Compiler-Exceptions'); smalltalk.RethrowErrorHandler.comment="This class is used in the commandline version of the compiler.\x0aIt uses the handleError: message of ErrorHandler for printing the stacktrace and throws the error again as JS exception.\x0aAs a result Smalltalk errors are not swallowd by the Amber runtime and compilation can be aborted."; smalltalk.addMethod( smalltalk.method({ selector: "basicSignal:", category: 'error handling', fn: function (anError){ var self=this; return smalltalk.withContext(function($ctx1) { throw anError; return self}, function($ctx1) {$ctx1.fill(self,"basicSignal:",{anError:anError},smalltalk.RethrowErrorHandler)})}, args: ["anError"], source: "basicSignal: anError\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.RethrowErrorHandler); smalltalk.addMethod( smalltalk.method({ selector: "handleError:", category: 'error handling', fn: function (anError){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.RethrowErrorHandler.superclass.fn.prototype._handleError_.apply(_st(self), [anError]); self._basicSignal_(anError); return self}, function($ctx1) {$ctx1.fill(self,"handleError:",{anError:anError},smalltalk.RethrowErrorHandler)})}, args: ["anError"], source: "handleError: anError\x0a\x09super handleError: anError.\x0a\x09self basicSignal: anError", messageSends: ["handleError:", "basicSignal:"], referencedClasses: [] }), smalltalk.RethrowErrorHandler); }); define("amber_core/Compiler-Core", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-Core'); smalltalk.packages["Compiler-Core"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('AbstractCodeGenerator', smalltalk.Object, ['currentClass', 'source'], 'Compiler-Core'); smalltalk.AbstractCodeGenerator.comment="I am the abstract super class of all code generators and provide their common API."; smalltalk.addMethod( smalltalk.method({ selector: "classNameFor:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st(aClass)._isMetaclass(); if(smalltalk.assert($2)){ $1=_st(_st(_st(aClass)._instanceClass())._name()).__comma(".klass"); } else { $3=_st(aClass)._isNil(); if(smalltalk.assert($3)){ $1="nil"; } else { $1=_st(aClass)._name(); }; }; return $1; }, function($ctx1) {$ctx1.fill(self,"classNameFor:",{aClass:aClass},smalltalk.AbstractCodeGenerator)})}, args: ["aClass"], source: "classNameFor: aClass\x0a\x09^aClass isMetaclass\x0a\x09\x09ifTrue: [aClass instanceClass name, '.klass']\x0a\x09\x09ifFalse: [\x0a\x09\x09aClass isNil\x0a\x09\x09\x09ifTrue: ['nil']\x0a\x09\x09\x09ifFalse: [aClass name]]", messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "compileNode:", category: 'compiling', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self._subclassResponsibility(); return self}, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode},smalltalk.AbstractCodeGenerator)})}, args: ["aNode"], source: "compileNode: aNode\x0a\x09self subclassResponsibility", messageSends: ["subclassResponsibility"], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "currentClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"currentClass",{},smalltalk.AbstractCodeGenerator)})}, args: [], source: "currentClass\x0a\x09^currentClass", messageSends: [], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "currentClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@currentClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"currentClass:",{aClass:aClass},smalltalk.AbstractCodeGenerator)})}, args: ["aClass"], source: "currentClass: aClass\x0a\x09currentClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "pseudoVariables", category: 'accessing', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._pseudoVariableNames(); return $1; }, function($ctx1) {$ctx1.fill(self,"pseudoVariables",{},smalltalk.AbstractCodeGenerator)})}, args: [], source: "pseudoVariables\x0a\x09^ Smalltalk current pseudoVariableNames", messageSends: ["pseudoVariableNames", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "safeVariableNameFor:", category: 'accessing', fn: function (aString){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st(_st($Smalltalk())._current())._reservedWords())._includes_(aString); if(smalltalk.assert($2)){ $1=_st(aString).__comma("_"); } else { $1=aString; }; return $1; }, function($ctx1) {$ctx1.fill(self,"safeVariableNameFor:",{aString:aString},smalltalk.AbstractCodeGenerator)})}, args: ["aString"], source: "safeVariableNameFor: aString\x0a\x09^(Smalltalk current reservedWords includes: aString)\x0a\x09\x09ifTrue: [aString, '_']\x0a\x09\x09ifFalse: [aString]", messageSends: ["ifTrue:ifFalse:", ",", "includes:", "reservedWords", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@source"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=""; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.AbstractCodeGenerator)})}, args: [], source: "source\x0a\x09^source ifNil: ['']", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.AbstractCodeGenerator)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.AbstractCodeGenerator); smalltalk.addClass('CodeGenerator', smalltalk.AbstractCodeGenerator, [], 'Compiler-Core'); smalltalk.CodeGenerator.comment="I am a basic code generator. I generate a valid JavaScript output, but no not perform any inlining.\x0aSee `InliningCodeGenerator` for an optimized JavaScript code generation."; smalltalk.addMethod( smalltalk.method({ selector: "compileNode:", category: 'compiling', fn: function (aNode){ var self=this; var ir,stream; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; _st(self._semanticAnalyzer())._visit_(aNode); ir=_st(self._translator())._visit_(aNode); $2=self._irTranslator(); _st($2)._currentClass_(self._currentClass()); _st($2)._visit_(ir); $3=_st($2)._contents(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,ir:ir,stream:stream},smalltalk.CodeGenerator)})}, args: ["aNode"], source: "compileNode: aNode\x0a\x09| ir stream |\x0a\x09self semanticAnalyzer visit: aNode.\x0a\x09ir := self translator visit: aNode.\x0a\x09^ self irTranslator\x0a\x09\x09currentClass: self currentClass;\x0a\x09\x09visit: ir;\x0a\x09\x09contents", messageSends: ["visit:", "semanticAnalyzer", "translator", "currentClass:", "currentClass", "irTranslator", "contents"], referencedClasses: [] }), smalltalk.CodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "irTranslator", category: 'compiling', fn: function (){ var self=this; function $IRJSTranslator(){return smalltalk.IRJSTranslator||(typeof IRJSTranslator=="undefined"?nil:IRJSTranslator)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRJSTranslator())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"irTranslator",{},smalltalk.CodeGenerator)})}, args: [], source: "irTranslator\x0a\x09^ IRJSTranslator new", messageSends: ["new"], referencedClasses: ["IRJSTranslator"] }), smalltalk.CodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "semanticAnalyzer", category: 'compiling', fn: function (){ var self=this; function $SemanticAnalyzer(){return smalltalk.SemanticAnalyzer||(typeof SemanticAnalyzer=="undefined"?nil:SemanticAnalyzer)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($SemanticAnalyzer())._on_(self._currentClass()); return $1; }, function($ctx1) {$ctx1.fill(self,"semanticAnalyzer",{},smalltalk.CodeGenerator)})}, args: [], source: "semanticAnalyzer\x0a\x09^ SemanticAnalyzer on: self currentClass", messageSends: ["on:", "currentClass"], referencedClasses: ["SemanticAnalyzer"] }), smalltalk.CodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "translator", category: 'compiling', fn: function (){ var self=this; function $IRASTTranslator(){return smalltalk.IRASTTranslator||(typeof IRASTTranslator=="undefined"?nil:IRASTTranslator)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRASTTranslator())._new(); _st($2)._source_(self._source()); _st($2)._theClass_(self._currentClass()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"translator",{},smalltalk.CodeGenerator)})}, args: [], source: "translator\x0a\x09^ IRASTTranslator new\x0a\x09\x09source: self source;\x0a\x09\x09theClass: self currentClass;\x0a\x09\x09yourself", messageSends: ["source:", "source", "new", "theClass:", "currentClass", "yourself"], referencedClasses: ["IRASTTranslator"] }), smalltalk.CodeGenerator); smalltalk.addClass('Compiler', smalltalk.Object, ['currentClass', 'source', 'unknownVariables', 'codeGeneratorClass'], 'Compiler-Core'); smalltalk.Compiler.comment="I provide the public interface for compiling Amber source code into JavaScript.\x0a\x0aThe code generator used to produce JavaScript can be plugged with `#codeGeneratorClass`.\x0aThe default code generator is an instance of `InlinedCodeGenerator`"; smalltalk.addMethod( smalltalk.method({ selector: "codeGeneratorClass", category: 'accessing', fn: function (){ var self=this; function $InliningCodeGenerator(){return smalltalk.InliningCodeGenerator||(typeof InliningCodeGenerator=="undefined"?nil:InliningCodeGenerator)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@codeGeneratorClass"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=$InliningCodeGenerator(); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"codeGeneratorClass",{},smalltalk.Compiler)})}, args: [], source: "codeGeneratorClass\x0a\x09^codeGeneratorClass ifNil: [InliningCodeGenerator]", messageSends: ["ifNil:"], referencedClasses: ["InliningCodeGenerator"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "codeGeneratorClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@codeGeneratorClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"codeGeneratorClass:",{aClass:aClass},smalltalk.Compiler)})}, args: ["aClass"], source: "codeGeneratorClass: aClass\x0a\x09codeGeneratorClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "compile:", category: 'compiling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._compileNode_(self._parse_(aString)); return $1; }, function($ctx1) {$ctx1.fill(self,"compile:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "compile: aString\x0a\x09^self compileNode: (self parse: aString)", messageSends: ["compileNode:", "parse:"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "compile:forClass:", category: 'compiling', fn: function (aString,aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._currentClass_(aClass); self._source_(aString); $1=self._compile_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"compile:forClass:",{aString:aString,aClass:aClass},smalltalk.Compiler)})}, args: ["aString", "aClass"], source: "compile: aString forClass: aClass\x0a\x09self currentClass: aClass.\x0a\x09self source: aString.\x0a\x09^self compile: aString", messageSends: ["currentClass:", "source:", "compile:"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "compileExpression:", category: 'compiling', fn: function (aString){ var self=this; function $DoIt(){return smalltalk.DoIt||(typeof DoIt=="undefined"?nil:DoIt)} return smalltalk.withContext(function($ctx1) { var $1; self._currentClass_($DoIt()); self._source_(_st("doIt ^[".__comma(aString)).__comma("] value")); $1=self._compileNode_(self._parse_(self._source())); return $1; }, function($ctx1) {$ctx1.fill(self,"compileExpression:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "compileExpression: aString\x0a\x09self currentClass: DoIt.\x0a\x09self source: 'doIt ^[', aString, '] value'.\x0a\x09^self compileNode: (self parse: self source)", messageSends: ["currentClass:", "source:", ",", "compileNode:", "parse:", "source"], referencedClasses: ["DoIt"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "compileExpression:on:", category: 'compiling', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._currentClass_(_st(anObject)._class()); self._source_(_st("xxxDoIt ^[".__comma(aString)).__comma("] value")); $1=self._compileNode_(self._parse_(self._source())); return $1; }, function($ctx1) {$ctx1.fill(self,"compileExpression:on:",{aString:aString,anObject:anObject},smalltalk.Compiler)})}, args: ["aString", "anObject"], source: "compileExpression: aString on: anObject\x0a\x09self currentClass: anObject class.\x0a\x09self source: 'xxxDoIt ^[', aString, '] value'.\x0a\x09^self compileNode: (self parse: self source)", messageSends: ["currentClass:", "class", "source:", ",", "compileNode:", "parse:", "source"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "compileNode:", category: 'compiling', fn: function (aNode){ var self=this; var generator,result; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; generator=_st(self._codeGeneratorClass())._new(); $1=generator; _st($1)._source_(self._source()); $2=_st($1)._currentClass_(self._currentClass()); result=_st(generator)._compileNode_(aNode); self._unknownVariables_([]); $3=result; return $3; }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,generator:generator,result:result},smalltalk.Compiler)})}, args: ["aNode"], source: "compileNode: aNode\x0a\x09| generator result |\x0a\x09generator := self codeGeneratorClass new.\x0a\x09generator\x0a\x09\x09source: self source;\x0a\x09\x09currentClass: self currentClass.\x0a\x09result := generator compileNode: aNode.\x0a\x09self unknownVariables: #().\x0a\x09^result", messageSends: ["new", "codeGeneratorClass", "source:", "source", "currentClass:", "currentClass", "compileNode:", "unknownVariables:"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "currentClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"currentClass",{},smalltalk.Compiler)})}, args: [], source: "currentClass\x0a\x09^currentClass", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "currentClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@currentClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"currentClass:",{aClass:aClass},smalltalk.Compiler)})}, args: ["aClass"], source: "currentClass: aClass\x0a\x09currentClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "eval:", category: 'compiling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return eval(aString); return self}, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "eval: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "evaluateExpression:", category: 'compiling', fn: function (aString){ var self=this; function $DoIt(){return smalltalk.DoIt||(typeof DoIt=="undefined"?nil:DoIt)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._evaluateExpression_on_(aString,_st($DoIt())._new()); return $1; }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "evaluateExpression: aString\x0a\x09\x22Unlike #eval: evaluate a Smalltalk expression and answer the returned object\x22\x0a\x09^ self evaluateExpression: aString on: DoIt new", messageSends: ["evaluateExpression:on:", "new"], referencedClasses: ["DoIt"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "evaluateExpression:on:", category: 'compiling', fn: function (aString,anObject){ var self=this; var result,method; return smalltalk.withContext(function($ctx1) { var $1; method=self._eval_(self._compileExpression_on_(aString,anObject)); _st(method)._category_("xxxDoIt"); _st(_st(anObject)._class())._addCompiledMethod_(method); result=_st(anObject)._xxxDoIt(); _st(_st(anObject)._class())._removeCompiledMethod_(method); $1=result; return $1; }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:on:",{aString:aString,anObject:anObject,result:result,method:method},smalltalk.Compiler)})}, args: ["aString", "anObject"], source: "evaluateExpression: aString on: anObject\x0a\x09\x22Unlike #eval: evaluate a Smalltalk expression with anObject as the receiver and answer the returned object\x22\x0a\x09| result method |\x0a\x09method := self eval: (self compileExpression: aString on: anObject).\x0a\x09method category: 'xxxDoIt'.\x0a\x09anObject class addCompiledMethod: method.\x0a\x09result := anObject xxxDoIt.\x0a\x09anObject class removeCompiledMethod: method.\x0a\x09^result", messageSends: ["eval:", "compileExpression:on:", "category:", "addCompiledMethod:", "class", "xxxDoIt", "removeCompiledMethod:"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "install:forClass:category:", category: 'compiling', fn: function (aString,aBehavior,anotherString){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($ClassBuilder())._new())._installMethod_forClass_category_(self._eval_(self._compile_forClass_(aString,aBehavior)),aBehavior,anotherString); return $1; }, function($ctx1) {$ctx1.fill(self,"install:forClass:category:",{aString:aString,aBehavior:aBehavior,anotherString:anotherString},smalltalk.Compiler)})}, args: ["aString", "aBehavior", "anotherString"], source: "install: aString forClass: aBehavior category: anotherString\x0a\x09^ ClassBuilder new\x0a\x09\x09installMethod: (self eval: (self compile: aString forClass: aBehavior))\x0a\x09\x09forClass: aBehavior\x0a\x09\x09category: anotherString", messageSends: ["installMethod:forClass:category:", "eval:", "compile:forClass:", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "parse:", category: 'compiling', fn: function (aString){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Smalltalk())._current())._parse_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "parse: aString\x0a\x09^Smalltalk current parse: aString", messageSends: ["parse:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "parseExpression:", category: 'compiling', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._parse_(_st("doIt ^[".__comma(aString)).__comma("] value")); return $1; }, function($ctx1) {$ctx1.fill(self,"parseExpression:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "parseExpression: aString\x0a\x09^self parse: 'doIt ^[', aString, '] value'", messageSends: ["parse:", ","], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "recompile:", category: 'compiling', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(_st(_st(aClass)._methodDictionary())._values())._do_displayingProgress_((function(each){ return smalltalk.withContext(function($ctx2) { return self._install_forClass_category_(_st(each)._source(),aClass,_st(each)._category()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),"Recompiling ".__comma(_st(aClass)._name())); $1=_st(aClass)._isMetaclass(); if(! smalltalk.assert($1)){ self._recompile_(_st(aClass)._class()); }; return self}, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},smalltalk.Compiler)})}, args: ["aClass"], source: "recompile: aClass\x0a\x09aClass methodDictionary values\x0a\x09\x09do: [ :each | self install: each source forClass: aClass category: each category ]\x0a\x09\x09displayingProgress: 'Recompiling ', aClass name.\x0a\x09\x22self setupClass: aClass.\x22\x0a\x09aClass isMetaclass ifFalse: [ self recompile: aClass class ]", messageSends: ["do:displayingProgress:", "install:forClass:category:", "source", "category", ",", "name", "values", "methodDictionary", "ifFalse:", "recompile:", "class", "isMetaclass"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "recompileAll", category: 'compiling', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { _st(_st(_st($Smalltalk())._current())._classes())._do_displayingProgress_((function(each){ return smalltalk.withContext(function($ctx2) { return self._recompile_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),"Compiling all classes..."); return self}, function($ctx1) {$ctx1.fill(self,"recompileAll",{},smalltalk.Compiler)})}, args: [], source: "recompileAll\x0a\x09Smalltalk current classes \x0a\x09\x09do: [:each | self recompile: each ]\x0a\x09\x09displayingProgress: 'Compiling all classes...'", messageSends: ["do:displayingProgress:", "recompile:", "classes", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@source"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=""; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.Compiler)})}, args: [], source: "source\x0a\x09^source ifNil: ['']", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.Compiler)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "unknownVariables", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@unknownVariables"]; return $1; }, function($ctx1) {$ctx1.fill(self,"unknownVariables",{},smalltalk.Compiler)})}, args: [], source: "unknownVariables\x0a\x09^unknownVariables", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "unknownVariables:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@unknownVariables"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"unknownVariables:",{aCollection:aCollection},smalltalk.Compiler)})}, args: ["aCollection"], source: "unknownVariables: aCollection\x0a\x09unknownVariables := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.Compiler); smalltalk.addMethod( smalltalk.method({ selector: "recompile:", category: 'compiling', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._new())._recompile_(aClass); return self}, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},smalltalk.Compiler.klass)})}, args: ["aClass"], source: "recompile: aClass\x0a\x09self new recompile: aClass", messageSends: ["recompile:", "new"], referencedClasses: [] }), smalltalk.Compiler.klass); smalltalk.addMethod( smalltalk.method({ selector: "recompileAll", category: 'compiling', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { _st(_st(_st($Smalltalk())._current())._classes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return self._recompile_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"recompileAll",{},smalltalk.Compiler.klass)})}, args: [], source: "recompileAll\x0a\x09Smalltalk current classes do: [:each |\x0a\x09\x09self recompile: each]", messageSends: ["do:", "recompile:", "classes", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.Compiler.klass); smalltalk.addClass('DoIt', smalltalk.Object, [], 'Compiler-Core'); smalltalk.DoIt.comment="`DoIt` is the class used to compile and evaluate expressions. See `Compiler >> evaluateExpression:`."; smalltalk.addClass('NodeVisitor', smalltalk.Object, [], 'Compiler-Core'); smalltalk.NodeVisitor.comment="I am the abstract super class of all AST node visitors."; smalltalk.addMethod( smalltalk.method({ selector: "visit:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aNode)._accept_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"visit:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visit: aNode\x0a\x09^ aNode accept: self", messageSends: ["accept:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitAll:", category: 'visiting', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aCollection)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"visitAll:",{aCollection:aCollection},smalltalk.NodeVisitor)})}, args: ["aCollection"], source: "visitAll: aCollection\x0a\x09^ aCollection collect: [ :each | self visit: each ]", messageSends: ["collect:", "visit:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitAssignmentNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitAssignmentNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitBlockNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitBlockNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitBlockSequenceNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitSequenceNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitBlockSequenceNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitBlockSequenceNode: aNode\x0a\x09^ self visitSequenceNode: aNode", messageSends: ["visitSequenceNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitCascadeNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitCascadeNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitClassReferenceNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitVariableNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitClassReferenceNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitClassReferenceNode: aNode\x0a\x09^ self visitVariableNode: aNode", messageSends: ["visitVariableNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitDynamicArrayNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitDynamicArrayNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitDynamicArrayNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitDynamicDictionaryNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitDynamicDictionaryNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitDynamicDictionaryNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitJSStatementNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitJSStatementNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitMethodNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitMethodNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitAll_(_st(aNode)._nodes()); return $1; }, function($ctx1) {$ctx1.fill(self,"visitNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitNode: aNode\x0a\x09^ self visitAll: aNode nodes", messageSends: ["visitAll:", "nodes"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitReturnNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitReturnNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitSendNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitSendNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitSequenceNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitSequenceNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitValueNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitValueNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitValueNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitVariableNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitNode_(aNode); return $1; }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},smalltalk.NodeVisitor)})}, args: ["aNode"], source: "visitVariableNode: aNode\x0a\x09^ self visitNode: aNode", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.NodeVisitor); }); define("amber_core/Compiler-AST", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects", "amber_core/Kernel-Methods"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-AST'); smalltalk.packages["Compiler-AST"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('Node', smalltalk.Object, ['parent', 'position', 'nodes', 'shouldBeInlined', 'shouldBeAliased'], 'Compiler-AST'); smalltalk.Node.comment="I am the abstract root class of the abstract syntax tree.\x0a\x0aConcrete classes should implement `#accept:` to allow visiting.\x0a\x0a`position` holds a point containing line and column number of the symbol location in the original source file."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.Node)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitNode: self", messageSends: ["visitNode:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "addNode:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._nodes())._add_(aNode); _st(aNode)._parent_(self); return self}, function($ctx1) {$ctx1.fill(self,"addNode:",{aNode:aNode},smalltalk.Node)})}, args: ["aNode"], source: "addNode: aNode\x0a\x09self nodes add: aNode.\x0a\x09aNode parent: self", messageSends: ["add:", "nodes", "parent:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "extent", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._nextNode(); if(($receiver = $2) == nil || $receiver == undefined){ $3=self._parent(); if(($receiver = $3) == nil || $receiver == undefined){ $1=$3; } else { var node; node=$receiver; $1=_st(node)._extent(); }; } else { var node; node=$receiver; $1=_st(node)._position(); }; return $1; }, function($ctx1) {$ctx1.fill(self,"extent",{},smalltalk.Node)})}, args: [], source: "extent\x0a\x09\x22Answer the line and column of the end position of the receiver in the source code\x22\x0a\x09\x0a\x09^ self nextNode \x0a\x09\x09ifNil: [ self parent ifNotNil: [ :node | node extent ] ]\x0a\x09\x09ifNotNil: [ :node | node position ]", messageSends: ["ifNil:ifNotNil:", "ifNotNil:", "extent", "parent", "position", "nextNode"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isAssignmentNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isAssignmentNode",{},smalltalk.Node)})}, args: [], source: "isAssignmentNode\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isBlockNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isBlockNode",{},smalltalk.Node)})}, args: [], source: "isBlockNode\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isBlockSequenceNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isBlockSequenceNode",{},smalltalk.Node)})}, args: [], source: "isBlockSequenceNode\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.Node)})}, args: [], source: "isImmutable\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isJSStatementNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isJSStatementNode",{},smalltalk.Node)})}, args: [], source: "isJSStatementNode\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isNode",{},smalltalk.Node)})}, args: [], source: "isNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isReturnNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isReturnNode",{},smalltalk.Node)})}, args: [], source: "isReturnNode\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isSendNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isSendNode",{},smalltalk.Node)})}, args: [], source: "isSendNode\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isValueNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isValueNode",{},smalltalk.Node)})}, args: [], source: "isValueNode\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "nextNode", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._parent(); if(($receiver = $2) == nil || $receiver == undefined){ $1=$2; } else { var node; node=$receiver; $1=_st(node)._nextNode_(self); }; return $1; }, function($ctx1) {$ctx1.fill(self,"nextNode",{},smalltalk.Node)})}, args: [], source: "nextNode\x0a\x09^ self parent ifNotNil: [ :node |\x0a\x09\x09node nextNode: self ]", messageSends: ["ifNotNil:", "nextNode:", "parent"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "nextNode:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._nodes())._at_ifAbsent_(_st(_st(self._nodes())._indexOf_(aNode)).__plus((1)),(function(){ return smalltalk.withContext(function($ctx2) { return nil; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"nextNode:",{aNode:aNode},smalltalk.Node)})}, args: ["aNode"], source: "nextNode: aNode\x0a\x09\x22Answer the next node after aNode\x22\x0a\x09\x0a\x09^ self nodes \x0a\x09\x09at: (self nodes indexOf: aNode) + 1\x0a\x09\x09ifAbsent: [ nil ]", messageSends: ["at:ifAbsent:", "+", "indexOf:", "nodes"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "nodes", category: 'accessing', fn: function (){ var self=this; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@nodes"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@nodes"]=_st($Array())._new(); $1=self["@nodes"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"nodes",{},smalltalk.Node)})}, args: [], source: "nodes\x0a\x09^nodes ifNil: [nodes := Array new]", messageSends: ["ifNil:", "new"], referencedClasses: ["Array"] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "nodes:", category: 'building', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@nodes"]=aCollection; _st(aCollection)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._parent_(self); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"nodes:",{aCollection:aCollection},smalltalk.Node)})}, args: ["aCollection"], source: "nodes: aCollection\x0a\x09nodes := aCollection.\x0a\x09aCollection do: [ :each | each parent: self ]", messageSends: ["do:", "parent:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "parent", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@parent"]; return $1; }, function($ctx1) {$ctx1.fill(self,"parent",{},smalltalk.Node)})}, args: [], source: "parent\x0a\x09^ parent", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "parent:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@parent"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"parent:",{aNode:aNode},smalltalk.Node)})}, args: ["aNode"], source: "parent: aNode\x0a\x09parent := aNode", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "position", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self["@position"]; if(($receiver = $2) == nil || $receiver == undefined){ $3=self._parent(); if(($receiver = $3) == nil || $receiver == undefined){ $1=$3; } else { var node; node=$receiver; $1=_st(node)._position(); }; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"position",{},smalltalk.Node)})}, args: [], source: "position\x0a\x09\x22answer the line and column of the receiver in the source code\x22\x0a\x09\x0a\x09^ position ifNil: [ \x0a\x09\x09self parent ifNotNil: [ :node | node position ] ]", messageSends: ["ifNil:", "ifNotNil:", "position", "parent"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "position:", category: 'building', fn: function (aPosition){ var self=this; return smalltalk.withContext(function($ctx1) { self["@position"]=aPosition; return self}, function($ctx1) {$ctx1.fill(self,"position:",{aPosition:aPosition},smalltalk.Node)})}, args: ["aPosition"], source: "position: aPosition\x0a\x09position := aPosition", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "shouldBeAliased", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@shouldBeAliased"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"shouldBeAliased",{},smalltalk.Node)})}, args: [], source: "shouldBeAliased\x0a\x09^ shouldBeAliased ifNil: [ false ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "shouldBeAliased:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@shouldBeAliased"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"shouldBeAliased:",{aBoolean:aBoolean},smalltalk.Node)})}, args: ["aBoolean"], source: "shouldBeAliased: aBoolean\x0a\x09shouldBeAliased := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "shouldBeInlined", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@shouldBeInlined"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"shouldBeInlined",{},smalltalk.Node)})}, args: [], source: "shouldBeInlined\x0a\x09^ shouldBeInlined ifNil: [ false ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "shouldBeInlined:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@shouldBeInlined"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"shouldBeInlined:",{aBoolean:aBoolean},smalltalk.Node)})}, args: ["aBoolean"], source: "shouldBeInlined: aBoolean\x0a\x09shouldBeInlined := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "stopOnStepping", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"stopOnStepping",{},smalltalk.Node)})}, args: [], source: "stopOnStepping\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "subtreeNeedsAliasing", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._shouldBeAliased())._or_((function(){ return smalltalk.withContext(function($ctx2) { return self._shouldBeInlined(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})))._or_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(self._nodes())._detect_ifNone_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(each)._subtreeNeedsAliasing(); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}),(function(){ return smalltalk.withContext(function($ctx3) { return false; }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})}))).__tild_eq(false); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},smalltalk.Node)})}, args: [], source: "subtreeNeedsAliasing\x0a\x09^(self shouldBeAliased or: [ self shouldBeInlined ]) or: [\x0a\x09\x09(self nodes detect: [ :each | each subtreeNeedsAliasing ] ifNone: [ false ]) ~= false ]", messageSends: ["or:", "~=", "detect:ifNone:", "subtreeNeedsAliasing", "nodes", "shouldBeInlined", "shouldBeAliased"], referencedClasses: [] }), smalltalk.Node); smalltalk.addClass('AssignmentNode', smalltalk.Node, ['left', 'right'], 'Compiler-AST'); smalltalk.AssignmentNode.comment="I represent an assignment node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitAssignmentNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.AssignmentNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitAssignmentNode: self", messageSends: ["visitAssignmentNode:"], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "isAssignmentNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isAssignmentNode",{},smalltalk.AssignmentNode)})}, args: [], source: "isAssignmentNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "left", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@left"]; return $1; }, function($ctx1) {$ctx1.fill(self,"left",{},smalltalk.AssignmentNode)})}, args: [], source: "left\x0a\x09^left", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "left:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@left"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"left:",{aNode:aNode},smalltalk.AssignmentNode)})}, args: ["aNode"], source: "left: aNode\x0a\x09left := aNode", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "nodes", category: 'accessing', fn: function (){ var self=this; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($Array())._with_with_(self._left(),self._right()); return $1; }, function($ctx1) {$ctx1.fill(self,"nodes",{},smalltalk.AssignmentNode)})}, args: [], source: "nodes\x0a\x09^ Array with: self left with: self right", messageSends: ["with:with:", "left", "right"], referencedClasses: ["Array"] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "right", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@right"]; return $1; }, function($ctx1) {$ctx1.fill(self,"right",{},smalltalk.AssignmentNode)})}, args: [], source: "right\x0a\x09^right", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "right:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@right"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"right:",{aNode:aNode},smalltalk.AssignmentNode)})}, args: ["aNode"], source: "right: aNode\x0a\x09right := aNode", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addClass('BlockNode', smalltalk.Node, ['parameters', 'scope'], 'Compiler-AST'); smalltalk.BlockNode.comment="I represent an block closure node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitBlockNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.BlockNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitBlockNode: self", messageSends: ["visitBlockNode:"], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "isBlockNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isBlockNode",{},smalltalk.BlockNode)})}, args: [], source: "isBlockNode\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "parameters", category: 'accessing', fn: function (){ var self=this; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@parameters"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@parameters"]=_st($Array())._new(); $1=self["@parameters"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"parameters",{},smalltalk.BlockNode)})}, args: [], source: "parameters\x0a\x09^parameters ifNil: [parameters := Array new]", messageSends: ["ifNil:", "new"], referencedClasses: ["Array"] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "parameters:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@parameters"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"parameters:",{aCollection:aCollection},smalltalk.BlockNode)})}, args: ["aCollection"], source: "parameters: aCollection\x0a\x09parameters := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.BlockNode)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aLexicalScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aLexicalScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aLexicalScope:aLexicalScope},smalltalk.BlockNode)})}, args: ["aLexicalScope"], source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope", messageSends: [], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "subtreeNeedsAliasing", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._shouldBeAliased())._or_((function(){ return smalltalk.withContext(function($ctx2) { return self._shouldBeInlined(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"subtreeNeedsAliasing",{},smalltalk.BlockNode)})}, args: [], source: "subtreeNeedsAliasing\x0a\x09^ self shouldBeAliased or: [ self shouldBeInlined ]", messageSends: ["or:", "shouldBeInlined", "shouldBeAliased"], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addClass('CascadeNode', smalltalk.Node, ['receiver'], 'Compiler-AST'); smalltalk.CascadeNode.comment="I represent an cascade node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitCascadeNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.CascadeNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitCascadeNode: self", messageSends: ["visitCascadeNode:"], referencedClasses: [] }), smalltalk.CascadeNode); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@receiver"]; return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.CascadeNode)})}, args: [], source: "receiver\x0a\x09^receiver", messageSends: [], referencedClasses: [] }), smalltalk.CascadeNode); smalltalk.addMethod( smalltalk.method({ selector: "receiver:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@receiver"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"receiver:",{aNode:aNode},smalltalk.CascadeNode)})}, args: ["aNode"], source: "receiver: aNode\x0a\x09receiver := aNode", messageSends: [], referencedClasses: [] }), smalltalk.CascadeNode); smalltalk.addClass('DynamicArrayNode', smalltalk.Node, [], 'Compiler-AST'); smalltalk.DynamicArrayNode.comment="I represent an dynamic array node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitDynamicArrayNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.DynamicArrayNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitDynamicArrayNode: self", messageSends: ["visitDynamicArrayNode:"], referencedClasses: [] }), smalltalk.DynamicArrayNode); smalltalk.addClass('DynamicDictionaryNode', smalltalk.Node, [], 'Compiler-AST'); smalltalk.DynamicDictionaryNode.comment="I represent an dynamic dictionary node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitDynamicDictionaryNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.DynamicDictionaryNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitDynamicDictionaryNode: self", messageSends: ["visitDynamicDictionaryNode:"], referencedClasses: [] }), smalltalk.DynamicDictionaryNode); smalltalk.addClass('JSStatementNode', smalltalk.Node, ['source'], 'Compiler-AST'); smalltalk.JSStatementNode.comment="I represent an JavaScript statement node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitJSStatementNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.JSStatementNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitJSStatementNode: self", messageSends: ["visitJSStatementNode:"], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addMethod( smalltalk.method({ selector: "isJSStatementNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isJSStatementNode",{},smalltalk.JSStatementNode)})}, args: [], source: "isJSStatementNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@source"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=""; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.JSStatementNode)})}, args: [], source: "source\x0a\x09^source ifNil: ['']", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.JSStatementNode)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addClass('MethodNode', smalltalk.Node, ['selector', 'arguments', 'source', 'scope', 'classReferences', 'messageSends', 'superSends'], 'Compiler-AST'); smalltalk.MethodNode.comment="I represent an method node.\x0a\x0aA method node must be the root and only method node of a valid AST."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitMethodNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.MethodNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitMethodNode: self", messageSends: ["visitMethodNode:"], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@arguments"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=[]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.MethodNode)})}, args: [], source: "arguments\x0a\x09^arguments ifNil: [#()]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "arguments:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@arguments"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"arguments:",{aCollection:aCollection},smalltalk.MethodNode)})}, args: ["aCollection"], source: "arguments: aCollection\x0a\x09arguments := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "classReferences", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@classReferences"]; return $1; }, function($ctx1) {$ctx1.fill(self,"classReferences",{},smalltalk.MethodNode)})}, args: [], source: "classReferences\x0a\x09^ classReferences", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "classReferences:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@classReferences"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"classReferences:",{aCollection:aCollection},smalltalk.MethodNode)})}, args: ["aCollection"], source: "classReferences: aCollection\x0a\x09classReferences := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "extent", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(self._source())._lines())._size()).__at(_st(_st(_st(_st(self._source())._lines())._last())._size()).__plus((1))); return $1; }, function($ctx1) {$ctx1.fill(self,"extent",{},smalltalk.MethodNode)})}, args: [], source: "extent\x0a\x09^ self source lines size @ (self source lines last size + 1)", messageSends: ["@", "+", "size", "last", "lines", "source"], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "messageSends", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@messageSends"]; return $1; }, function($ctx1) {$ctx1.fill(self,"messageSends",{},smalltalk.MethodNode)})}, args: [], source: "messageSends\x0a\x09^ messageSends", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "messageSends:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@messageSends"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"messageSends:",{aCollection:aCollection},smalltalk.MethodNode)})}, args: ["aCollection"], source: "messageSends: aCollection\x0a\x09messageSends := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.MethodNode)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aMethodScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aMethodScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aMethodScope:aMethodScope},smalltalk.MethodNode)})}, args: ["aMethodScope"], source: "scope: aMethodScope\x0a\x09scope := aMethodScope", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@selector"]; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.MethodNode)})}, args: [], source: "selector\x0a\x09^selector", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@selector"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.MethodNode)})}, args: ["aString"], source: "selector: aString\x0a\x09selector := aString", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@source"]; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.MethodNode)})}, args: [], source: "source\x0a\x09^source", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.MethodNode)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "superSends", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@superSends"]; return $1; }, function($ctx1) {$ctx1.fill(self,"superSends",{},smalltalk.MethodNode)})}, args: [], source: "superSends\x0a\x09^ superSends", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "superSends:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@superSends"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"superSends:",{aCollection:aCollection},smalltalk.MethodNode)})}, args: ["aCollection"], source: "superSends: aCollection\x0a\x09superSends := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addClass('ReturnNode', smalltalk.Node, ['scope'], 'Compiler-AST'); smalltalk.ReturnNode.comment="I represent an return node. At the AST level, there is not difference between a local return or non-local return."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitReturnNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.ReturnNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitReturnNode: self", messageSends: ["visitReturnNode:"], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addMethod( smalltalk.method({ selector: "isReturnNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isReturnNode",{},smalltalk.ReturnNode)})}, args: [], source: "isReturnNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addMethod( smalltalk.method({ selector: "nonLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._scope())._isMethodScope())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"nonLocalReturn",{},smalltalk.ReturnNode)})}, args: [], source: "nonLocalReturn\x0a\x09^ self scope isMethodScope not", messageSends: ["not", "isMethodScope", "scope"], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.ReturnNode)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aLexicalScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aLexicalScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aLexicalScope:aLexicalScope},smalltalk.ReturnNode)})}, args: ["aLexicalScope"], source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope", messageSends: [], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addClass('SendNode', smalltalk.Node, ['selector', 'arguments', 'receiver', 'superSend', 'index'], 'Compiler-AST'); smalltalk.SendNode.comment="I represent an message send node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitSendNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.SendNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitSendNode: self", messageSends: ["visitSendNode:"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@arguments"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@arguments"]=[]; $1=self["@arguments"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.SendNode)})}, args: [], source: "arguments\x0a\x09^arguments ifNil: [arguments := #()]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "arguments:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@arguments"]=aCollection; _st(aCollection)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._parent_(self); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"arguments:",{aCollection:aCollection},smalltalk.SendNode)})}, args: ["aCollection"], source: "arguments: aCollection\x0a\x09arguments := aCollection.\x0a\x09aCollection do: [ :each | each parent: self ]", messageSends: ["do:", "parent:"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "cascadeNodeWithMessages:", category: 'accessing', fn: function (aCollection){ var self=this; var first; function $SendNode(){return smalltalk.SendNode||(typeof SendNode=="undefined"?nil:SendNode)} function $CascadeNode(){return smalltalk.CascadeNode||(typeof CascadeNode=="undefined"?nil:CascadeNode)} function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1,$2,$4,$5,$3; $1=_st($SendNode())._new(); _st($1)._selector_(self._selector()); _st($1)._arguments_(self._arguments()); $2=_st($1)._yourself(); first=$2; $4=_st($CascadeNode())._new(); _st($4)._receiver_(self._receiver()); _st($4)._nodes_(_st(_st($Array())._with_(first)).__comma(aCollection)); $5=_st($4)._yourself(); $3=$5; return $3; }, function($ctx1) {$ctx1.fill(self,"cascadeNodeWithMessages:",{aCollection:aCollection,first:first},smalltalk.SendNode)})}, args: ["aCollection"], source: "cascadeNodeWithMessages: aCollection\x0a\x09| first |\x0a\x09first := SendNode new\x0a\x09\x09selector: self selector;\x0a\x09\x09arguments: self arguments;\x0a\x09\x09yourself.\x0a\x09^CascadeNode new\x0a\x09\x09receiver: self receiver;\x0a\x09\x09nodes: (Array with: first), aCollection;\x0a\x09\x09yourself", messageSends: ["selector:", "selector", "new", "arguments:", "arguments", "yourself", "receiver:", "receiver", "nodes:", ",", "with:"], referencedClasses: ["SendNode", "CascadeNode", "Array"] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "index", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@index"]; return $1; }, function($ctx1) {$ctx1.fill(self,"index",{},smalltalk.SendNode)})}, args: [], source: "index\x0a\x09^ index", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "index:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@index"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"index:",{anInteger:anInteger},smalltalk.SendNode)})}, args: ["anInteger"], source: "index: anInteger\x0a\x09index := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "isSendNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSendNode",{},smalltalk.SendNode)})}, args: [], source: "isSendNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "nodes", category: 'accessing', fn: function (){ var self=this; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($Array())._withAll_(self._arguments()); _st($2)._add_(self._receiver()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"nodes",{},smalltalk.SendNode)})}, args: [], source: "nodes\x0a\x09^ (Array withAll: self arguments)\x0a\x09\x09add: self receiver;\x0a\x09\x09yourself", messageSends: ["add:", "receiver", "withAll:", "arguments", "yourself"], referencedClasses: ["Array"] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@receiver"]; return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.SendNode)})}, args: [], source: "receiver\x0a\x09^receiver", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "receiver:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self["@receiver"]=aNode; $1=_st(aNode)._isNode(); if(smalltalk.assert($1)){ _st(aNode)._parent_(self); }; return self}, function($ctx1) {$ctx1.fill(self,"receiver:",{aNode:aNode},smalltalk.SendNode)})}, args: ["aNode"], source: "receiver: aNode\x0a\x09receiver := aNode.\x0a\x09aNode isNode ifTrue: [\x0a\x09\x09aNode parent: self ]", messageSends: ["ifTrue:", "parent:", "isNode"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@selector"]; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.SendNode)})}, args: [], source: "selector\x0a\x09^selector", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@selector"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.SendNode)})}, args: ["aString"], source: "selector: aString\x0a\x09selector := aString", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "stopOnStepping", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"stopOnStepping",{},smalltalk.SendNode)})}, args: [], source: "stopOnStepping\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "superSend", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@superSend"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"superSend",{},smalltalk.SendNode)})}, args: [], source: "superSend\x0a\x09^ superSend ifNil: [ false ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "superSend:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@superSend"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"superSend:",{aBoolean:aBoolean},smalltalk.SendNode)})}, args: ["aBoolean"], source: "superSend: aBoolean\x0a\x09superSend := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "valueForReceiver:", category: 'accessing', fn: function (anObject){ var self=this; function $SendNode(){return smalltalk.SendNode||(typeof SendNode=="undefined"?nil:SendNode)} return smalltalk.withContext(function($ctx1) { var $2,$3,$5,$4,$6,$1; $2=_st($SendNode())._new(); _st($2)._position_(self._position()); $3=$2; $5=self._receiver(); if(($receiver = $5) == nil || $receiver == undefined){ $4=anObject; } else { $4=_st(self._receiver())._valueForReceiver_(anObject); }; _st($3)._receiver_($4); _st($2)._selector_(self._selector()); _st($2)._arguments_(self._arguments()); $6=_st($2)._yourself(); $1=$6; return $1; }, function($ctx1) {$ctx1.fill(self,"valueForReceiver:",{anObject:anObject},smalltalk.SendNode)})}, args: ["anObject"], source: "valueForReceiver: anObject\x0a\x09^SendNode new\x0a\x09\x09position: self position;\x0a\x09\x09receiver: (self receiver\x0a\x09\x09ifNil: [anObject]\x0a\x09\x09ifNotNil: [self receiver valueForReceiver: anObject]);\x0a\x09\x09selector: self selector;\x0a\x09\x09arguments: self arguments;\x0a\x09\x09yourself", messageSends: ["position:", "position", "new", "receiver:", "ifNil:ifNotNil:", "valueForReceiver:", "receiver", "selector:", "selector", "arguments:", "arguments", "yourself"], referencedClasses: ["SendNode"] }), smalltalk.SendNode); smalltalk.addClass('SequenceNode', smalltalk.Node, ['temps', 'scope'], 'Compiler-AST'); smalltalk.SequenceNode.comment="I represent an sequence node. A sequence represent a set of instructions inside the same scope (the method scope or a block scope)."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitSequenceNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.SequenceNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitSequenceNode: self", messageSends: ["visitSequenceNode:"], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "asBlockSequenceNode", category: 'testing', fn: function (){ var self=this; function $BlockSequenceNode(){return smalltalk.BlockSequenceNode||(typeof BlockSequenceNode=="undefined"?nil:BlockSequenceNode)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($BlockSequenceNode())._new(); _st($2)._position_(self._position()); _st($2)._nodes_(self._nodes()); _st($2)._temps_(self._temps()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"asBlockSequenceNode",{},smalltalk.SequenceNode)})}, args: [], source: "asBlockSequenceNode\x0a\x09^BlockSequenceNode new\x0a\x09\x09position: self position;\x0a\x09\x09nodes: self nodes;\x0a\x09\x09temps: self temps;\x0a\x09\x09yourself", messageSends: ["position:", "position", "new", "nodes:", "nodes", "temps:", "temps", "yourself"], referencedClasses: ["BlockSequenceNode"] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.SequenceNode)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aLexicalScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aLexicalScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aLexicalScope:aLexicalScope},smalltalk.SequenceNode)})}, args: ["aLexicalScope"], source: "scope: aLexicalScope\x0a\x09scope := aLexicalScope", messageSends: [], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "temps", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@temps"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=[]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"temps",{},smalltalk.SequenceNode)})}, args: [], source: "temps\x0a\x09^temps ifNil: [#()]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "temps:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@temps"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"temps:",{aCollection:aCollection},smalltalk.SequenceNode)})}, args: ["aCollection"], source: "temps: aCollection\x0a\x09temps := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addClass('BlockSequenceNode', smalltalk.SequenceNode, [], 'Compiler-AST'); smalltalk.BlockSequenceNode.comment="I represent an special sequence node for block scopes."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitBlockSequenceNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.BlockSequenceNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitBlockSequenceNode: self", messageSends: ["visitBlockSequenceNode:"], referencedClasses: [] }), smalltalk.BlockSequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "isBlockSequenceNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isBlockSequenceNode",{},smalltalk.BlockSequenceNode)})}, args: [], source: "isBlockSequenceNode\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.BlockSequenceNode); smalltalk.addClass('ValueNode', smalltalk.Node, ['value'], 'Compiler-AST'); smalltalk.ValueNode.comment="I represent a value node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitValueNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.ValueNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitValueNode: self", messageSends: ["visitValueNode:"], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._value())._isImmutable(); return $1; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.ValueNode)})}, args: [], source: "isImmutable\x0a\x09^ self value isImmutable", messageSends: ["isImmutable", "value"], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addMethod( smalltalk.method({ selector: "isValueNode", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isValueNode",{},smalltalk.ValueNode)})}, args: [], source: "isValueNode\x0a\x09^true", messageSends: [], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@value"]; return $1; }, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.ValueNode)})}, args: [], source: "value\x0a\x09^value", messageSends: [], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@value"]=anObject; return self}, function($ctx1) {$ctx1.fill(self,"value:",{anObject:anObject},smalltalk.ValueNode)})}, args: ["anObject"], source: "value: anObject\x0a\x09value := anObject", messageSends: [], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addClass('VariableNode', smalltalk.ValueNode, ['assigned', 'binding'], 'Compiler-AST'); smalltalk.VariableNode.comment="I represent an variable node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitVariableNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.VariableNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitVariableNode: self", messageSends: ["visitVariableNode:"], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._binding())._alias(); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.VariableNode)})}, args: [], source: "alias\x0a\x09^ self binding alias", messageSends: ["alias", "binding"], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "assigned", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@assigned"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"assigned",{},smalltalk.VariableNode)})}, args: [], source: "assigned\x0a\x09^assigned ifNil: [false]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "assigned:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@assigned"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"assigned:",{aBoolean:aBoolean},smalltalk.VariableNode)})}, args: ["aBoolean"], source: "assigned: aBoolean\x0a\x09assigned := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "beAssigned", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._binding())._validateAssignment(); self["@assigned"]=true; return self}, function($ctx1) {$ctx1.fill(self,"beAssigned",{},smalltalk.VariableNode)})}, args: [], source: "beAssigned\x0a\x09self binding validateAssignment.\x0a\x09assigned := true", messageSends: ["validateAssignment", "binding"], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "binding", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@binding"]; return $1; }, function($ctx1) {$ctx1.fill(self,"binding",{},smalltalk.VariableNode)})}, args: [], source: "binding\x0a\x09^ binding", messageSends: [], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "binding:", category: 'accessing', fn: function (aScopeVar){ var self=this; return smalltalk.withContext(function($ctx1) { self["@binding"]=aScopeVar; return self}, function($ctx1) {$ctx1.fill(self,"binding:",{aScopeVar:aScopeVar},smalltalk.VariableNode)})}, args: ["aScopeVar"], source: "binding: aScopeVar\x0a\x09binding := aScopeVar", messageSends: [], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "isImmutable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isImmutable",{},smalltalk.VariableNode)})}, args: [], source: "isImmutable\x0a\x09^false", messageSends: [], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addClass('ClassReferenceNode', smalltalk.VariableNode, [], 'Compiler-AST'); smalltalk.ClassReferenceNode.comment="I represent an class reference node."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitClassReferenceNode_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.ClassReferenceNode)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitClassReferenceNode: self", messageSends: ["visitClassReferenceNode:"], referencedClasses: [] }), smalltalk.ClassReferenceNode); smalltalk.addMethod( smalltalk.method({ selector: "isNode", category: '*Compiler-AST', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isNode",{},smalltalk.Object)})}, args: [], source: "isNode\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Object); smalltalk.addMethod( smalltalk.method({ selector: "ast", category: '*Compiler-AST', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1; _st(self._source())._ifEmpty_((function(){ return smalltalk.withContext(function($ctx2) { return self._error_("Method source is empty"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=_st(_st($Smalltalk())._current())._parse_(self._source()); return $1; }, function($ctx1) {$ctx1.fill(self,"ast",{},smalltalk.CompiledMethod)})}, args: [], source: "ast\x0a\x09self source ifEmpty: [ self error: 'Method source is empty' ].\x0a\x09\x0a\x09^ Smalltalk current parse: self source", messageSends: ["ifEmpty:", "error:", "source", "parse:", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.CompiledMethod); }); define("amber_core/Compiler-IR", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Compiler-Core", "amber_core/Kernel-Objects", "amber_core/Kernel-Methods", "amber_core/Kernel-Collections"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-IR'); smalltalk.packages["Compiler-IR"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('IRASTTranslator', smalltalk.NodeVisitor, ['source', 'theClass', 'method', 'sequence', 'nextAlias'], 'Compiler-IR'); smalltalk.IRASTTranslator.comment="I am the AST (abstract syntax tree) visitor responsible for building the intermediate representation graph."; smalltalk.addMethod( smalltalk.method({ selector: "alias:", category: 'visiting', fn: function (aNode){ var self=this; var variable; function $AliasVar(){return smalltalk.AliasVar||(typeof AliasVar=="undefined"?nil:AliasVar)} function $IRVariable(){return smalltalk.IRVariable||(typeof IRVariable=="undefined"?nil:IRVariable)} function $IRAssignment(){return smalltalk.IRAssignment||(typeof IRAssignment=="undefined"?nil:IRAssignment)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7; $1=_st(aNode)._isImmutable(); if(smalltalk.assert($1)){ $2=self._visit_(aNode); return $2; }; $3=_st($IRVariable())._new(); _st($3)._variable_(_st(_st($AliasVar())._new())._name_("$".__comma(self._nextAlias()))); $4=_st($3)._yourself(); variable=$4; $5=_st($IRAssignment())._new(); _st($5)._add_(variable); _st($5)._add_(self._visit_(aNode)); $6=_st($5)._yourself(); _st(self._sequence())._add_($6); _st(_st(self._method())._internalVariables())._add_(variable); $7=variable; return $7; }, function($ctx1) {$ctx1.fill(self,"alias:",{aNode:aNode,variable:variable},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "alias: aNode\x0a\x09| variable |\x0a\x0a\x09aNode isImmutable ifTrue: [ ^ self visit: aNode ].\x0a\x0a\x09variable := IRVariable new\x0a\x09\x09variable: (AliasVar new name: '$', self nextAlias);\x0a\x09\x09yourself.\x0a\x0a\x09self sequence add: (IRAssignment new\x0a\x09\x09add: variable;\x0a\x09\x09add: (self visit: aNode);\x0a\x09\x09yourself).\x0a\x0a\x09self method internalVariables add: variable.\x0a\x0a\x09^ variable", messageSends: ["ifTrue:", "visit:", "isImmutable", "variable:", "name:", ",", "nextAlias", "new", "yourself", "add:", "sequence", "internalVariables", "method"], referencedClasses: ["AliasVar", "IRVariable", "IRAssignment"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "aliasTemporally:", category: 'visiting', fn: function (aCollection){ var self=this; var threshold,result; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $1,$2,$4,$3,$5; threshold=(0); _st(aCollection)._withIndexDo_((function(each,i){ return smalltalk.withContext(function($ctx2) { $1=_st(each)._subtreeNeedsAliasing(); if(smalltalk.assert($1)){ threshold=i; return threshold; }; }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1)})})); result=_st($OrderedCollection())._new(); _st(aCollection)._withIndexDo_((function(each,i){ return smalltalk.withContext(function($ctx2) { $2=result; $4=_st(i).__lt_eq(threshold); if(smalltalk.assert($4)){ $3=self._alias_(each); } else { $3=self._visit_(each); }; return _st($2)._add_($3); }, function($ctx2) {$ctx2.fillBlock({each:each,i:i},$ctx1)})})); $5=result; return $5; }, function($ctx1) {$ctx1.fill(self,"aliasTemporally:",{aCollection:aCollection,threshold:threshold,result:result},smalltalk.IRASTTranslator)})}, args: ["aCollection"], source: "aliasTemporally: aCollection\x0a\x09\x22https://github.com/NicolasPetton/amber/issues/296\x0a\x09\x0a\x09If a node is aliased, all preceding ones are aliased as well.\x0a\x09The tree is iterated twice. First we get the aliasing dependency,\x0a\x09then the aliasing itself is done\x22\x0a\x0a\x09| threshold result |\x0a\x09threshold := 0.\x0a\x09\x0a\x09aCollection withIndexDo: [ :each :i |\x0a\x09\x09each subtreeNeedsAliasing\x0a\x09\x09\x09ifTrue: [ threshold := i ]].\x0a\x0a\x09result := OrderedCollection new.\x0a\x09aCollection withIndexDo: [ :each :i |\x0a\x09\x09result add: (i <= threshold\x0a\x09\x09\x09ifTrue: [ self alias: each ]\x0a\x09\x09\x09ifFalse: [ self visit: each ])].\x0a\x0a\x09^result", messageSends: ["withIndexDo:", "ifTrue:", "subtreeNeedsAliasing", "new", "add:", "ifTrue:ifFalse:", "alias:", "visit:", "<="], referencedClasses: ["OrderedCollection"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@method"]; return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.IRASTTranslator)})}, args: [], source: "method\x0a\x09^ method", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "method:", category: 'accessing', fn: function (anIRMethod){ var self=this; return smalltalk.withContext(function($ctx1) { self["@method"]=anIRMethod; return self}, function($ctx1) {$ctx1.fill(self,"method:",{anIRMethod:anIRMethod},smalltalk.IRASTTranslator)})}, args: ["anIRMethod"], source: "method: anIRMethod\x0a\x09method := anIRMethod", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "nextAlias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self["@nextAlias"]; if(($receiver = $1) == nil || $receiver == undefined){ self["@nextAlias"]=(0); self["@nextAlias"]; } else { $1; }; self["@nextAlias"]=_st(self["@nextAlias"]).__plus((1)); $2=_st(self["@nextAlias"])._asString(); return $2; }, function($ctx1) {$ctx1.fill(self,"nextAlias",{},smalltalk.IRASTTranslator)})}, args: [], source: "nextAlias\x0a\x09nextAlias ifNil: [ nextAlias := 0 ].\x0a\x09nextAlias := nextAlias + 1.\x0a\x09^ nextAlias asString", messageSends: ["ifNil:", "+", "asString"], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "sequence", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@sequence"]; return $1; }, function($ctx1) {$ctx1.fill(self,"sequence",{},smalltalk.IRASTTranslator)})}, args: [], source: "sequence\x0a\x09^ sequence", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "sequence:", category: 'accessing', fn: function (anIRSequence){ var self=this; return smalltalk.withContext(function($ctx1) { self["@sequence"]=anIRSequence; return self}, function($ctx1) {$ctx1.fill(self,"sequence:",{anIRSequence:anIRSequence},smalltalk.IRASTTranslator)})}, args: ["anIRSequence"], source: "sequence: anIRSequence\x0a\x09sequence := anIRSequence", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@source"]; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.IRASTTranslator)})}, args: [], source: "source\x0a\x09^ source", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.IRASTTranslator)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.IRASTTranslator)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.IRASTTranslator)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitAssignmentNode:", category: 'visiting', fn: function (aNode){ var self=this; var left,right,assignment; function $IRAssignment(){return smalltalk.IRAssignment||(typeof IRAssignment=="undefined"?nil:IRAssignment)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; right=self._visit_(_st(aNode)._right()); left=self._visit_(_st(aNode)._left()); $1=_st($IRAssignment())._new(); _st($1)._add_(left); _st($1)._add_(right); $2=_st($1)._yourself(); _st(self._sequence())._add_($2); $3=left; return $3; }, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode,left:left,right:right,assignment:assignment},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitAssignmentNode: aNode\x0a\x09| left right assignment |\x0a\x09right := self visit: aNode right.\x0a\x09left := self visit: aNode left.\x0a\x09self sequence add: (IRAssignment new\x0a\x09\x09add: left;\x0a\x09\x09add: right;\x0a\x09\x09yourself).\x0a\x09^ left", messageSends: ["visit:", "right", "left", "add:", "new", "yourself", "sequence"], referencedClasses: ["IRAssignment"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitBlockNode:", category: 'visiting', fn: function (aNode){ var self=this; var closure; function $IRClosure(){return smalltalk.IRClosure||(typeof IRClosure=="undefined"?nil:IRClosure)} function $IRTempDeclaration(){return smalltalk.IRTempDeclaration||(typeof IRTempDeclaration=="undefined"?nil:IRTempDeclaration)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; $1=_st($IRClosure())._new(); _st($1)._arguments_(_st(aNode)._parameters()); _st($1)._scope_(_st(aNode)._scope()); $2=_st($1)._yourself(); closure=$2; _st(_st(_st(aNode)._scope())._temps())._do_((function(each){ return smalltalk.withContext(function($ctx2) { $3=_st($IRTempDeclaration())._new(); _st($3)._name_(_st(each)._name()); _st($3)._scope_(_st(aNode)._scope()); $4=_st($3)._yourself(); return _st(closure)._add_($4); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(closure)._add_(self._visit_(each)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $5=closure; return $5; }, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode,closure:closure},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitBlockNode: aNode\x0a\x09| closure |\x0a\x09closure := IRClosure new\x0a\x09\x09arguments: aNode parameters;\x0a\x09\x09scope: aNode scope;\x0a\x09\x09yourself.\x0a\x09aNode scope temps do: [ :each |\x0a\x09\x09closure add: (IRTempDeclaration new\x0a\x09\x09\x09name: each name;\x0a\x09\x09\x09scope: aNode scope;\x0a\x09\x09\x09yourself) ].\x0a\x09aNode nodes do: [ :each | closure add: (self visit: each) ].\x0a\x09^ closure", messageSends: ["arguments:", "parameters", "new", "scope:", "scope", "yourself", "do:", "add:", "name:", "name", "temps", "visit:", "nodes"], referencedClasses: ["IRClosure", "IRTempDeclaration"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitBlockSequenceNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRBlockSequence(){return smalltalk.IRBlockSequence||(typeof IRBlockSequence=="undefined"?nil:IRBlockSequence)} function $IRBlockReturn(){return smalltalk.IRBlockReturn||(typeof IRBlockReturn=="undefined"?nil:IRBlockReturn)} return smalltalk.withContext(function($ctx1) { var $2,$3,$4,$1; $1=self._withSequence_do_(_st($IRBlockSequence())._new(),(function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(aNode)._nodes())._ifNotEmpty_((function(){ return smalltalk.withContext(function($ctx3) { _st(_st(_st(aNode)._nodes())._allButLast())._do_((function(each){ return smalltalk.withContext(function($ctx4) { return _st(self._sequence())._add_(self._visit_(each)); }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3)})})); $2=_st(_st(_st(aNode)._nodes())._last())._isReturnNode(); if(smalltalk.assert($2)){ return _st(self._sequence())._add_(self._visit_(_st(_st(aNode)._nodes())._last())); } else { $3=_st($IRBlockReturn())._new(); _st($3)._add_(self._visit_(_st(_st(aNode)._nodes())._last())); $4=_st($3)._yourself(); return _st(self._sequence())._add_($4); }; }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"visitBlockSequenceNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitBlockSequenceNode: aNode\x0a\x09^ self\x0a\x09\x09withSequence: IRBlockSequence new\x0a\x09\x09do: [\x0a\x09\x09\x09aNode nodes ifNotEmpty: [\x0a\x09\x09\x09\x09aNode nodes allButLast do: [ :each |\x0a\x09\x09\x09\x09\x09self sequence add: (self visit: each) ].\x0a\x09\x09\x09\x09aNode nodes last isReturnNode\x0a\x09\x09\x09\x09\x09ifFalse: [ self sequence add: (IRBlockReturn new add: (self visit: aNode nodes last); yourself) ]\x0a\x09\x09\x09\x09\x09ifTrue: [ self sequence add: (self visit: aNode nodes last) ]]]", messageSends: ["withSequence:do:", "new", "ifNotEmpty:", "do:", "add:", "visit:", "sequence", "allButLast", "nodes", "ifFalse:ifTrue:", "last", "yourself", "isReturnNode"], referencedClasses: ["IRBlockSequence", "IRBlockReturn"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitCascadeNode:", category: 'visiting', fn: function (aNode){ var self=this; var alias; function $VariableNode(){return smalltalk.VariableNode||(typeof VariableNode=="undefined"?nil:VariableNode)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(_st(aNode)._receiver())._isImmutable(); if(! smalltalk.assert($1)){ alias=self._alias_(_st(aNode)._receiver()); alias; _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._receiver_(_st(_st($VariableNode())._new())._binding_(_st(alias)._variable())); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); }; _st(_st(_st(aNode)._nodes())._allButLast())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self._sequence())._add_(self._visit_(each)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=self._alias_(_st(_st(aNode)._nodes())._last()); return $2; }, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode,alias:alias},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitCascadeNode: aNode\x0a\x09| alias |\x0a\x0a\x09aNode receiver isImmutable ifFalse: [\x0a\x09\x09alias := self alias: aNode receiver.\x0a\x09\x09aNode nodes do: [ :each |\x0a\x09\x09\x09each receiver: (VariableNode new binding: alias variable) ]].\x0a\x0a\x09aNode nodes allButLast do: [ :each |\x0a\x09\x09self sequence add: (self visit: each) ].\x0a\x0a\x09^ self alias: aNode nodes last", messageSends: ["ifFalse:", "alias:", "receiver", "do:", "receiver:", "binding:", "variable", "new", "nodes", "isImmutable", "add:", "visit:", "sequence", "allButLast", "last"], referencedClasses: ["VariableNode"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitDynamicArrayNode:", category: 'visiting', fn: function (aNode){ var self=this; var array; function $IRDynamicArray(){return smalltalk.IRDynamicArray||(typeof IRDynamicArray=="undefined"?nil:IRDynamicArray)} return smalltalk.withContext(function($ctx1) { var $1; array=_st($IRDynamicArray())._new(); _st(self._aliasTemporally_(_st(aNode)._nodes()))._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(array)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=array; return $1; }, function($ctx1) {$ctx1.fill(self,"visitDynamicArrayNode:",{aNode:aNode,array:array},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitDynamicArrayNode: aNode\x0a\x09| array |\x0a\x09array := IRDynamicArray new.\x0a\x09(self aliasTemporally: aNode nodes) do: [:each | array add: each].\x0a\x09^ array", messageSends: ["new", "do:", "add:", "aliasTemporally:", "nodes"], referencedClasses: ["IRDynamicArray"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitDynamicDictionaryNode:", category: 'visiting', fn: function (aNode){ var self=this; var dictionary; function $IRDynamicDictionary(){return smalltalk.IRDynamicDictionary||(typeof IRDynamicDictionary=="undefined"?nil:IRDynamicDictionary)} return smalltalk.withContext(function($ctx1) { var $1; dictionary=_st($IRDynamicDictionary())._new(); _st(self._aliasTemporally_(_st(aNode)._nodes()))._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(dictionary)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=dictionary; return $1; }, function($ctx1) {$ctx1.fill(self,"visitDynamicDictionaryNode:",{aNode:aNode,dictionary:dictionary},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitDynamicDictionaryNode: aNode\x0a\x09| dictionary |\x0a\x09dictionary := IRDynamicDictionary new.\x0a\x09(self aliasTemporally: aNode nodes) do: [:each | dictionary add: each].\x0a\x09^ dictionary", messageSends: ["new", "do:", "add:", "aliasTemporally:", "nodes"], referencedClasses: ["IRDynamicDictionary"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitJSStatementNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRVerbatim(){return smalltalk.IRVerbatim||(typeof IRVerbatim=="undefined"?nil:IRVerbatim)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRVerbatim())._new(); _st($2)._source_(_st(_st(aNode)._source())._crlfSanitized()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitJSStatementNode: aNode\x0a\x09^ IRVerbatim new\x0a\x09\x09source: aNode source crlfSanitized;\x0a\x09\x09yourself", messageSends: ["source:", "crlfSanitized", "source", "new", "yourself"], referencedClasses: ["IRVerbatim"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitMethodNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRMethod(){return smalltalk.IRMethod||(typeof IRMethod=="undefined"?nil:IRMethod)} function $IRTempDeclaration(){return smalltalk.IRTempDeclaration||(typeof IRTempDeclaration=="undefined"?nil:IRTempDeclaration)} function $IRVariable(){return smalltalk.IRVariable||(typeof IRVariable=="undefined"?nil:IRVariable)} function $IRReturn(){return smalltalk.IRReturn||(typeof IRReturn=="undefined"?nil:IRReturn)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7,$8; $1=_st($IRMethod())._new(); _st($1)._source_(_st(self._source())._crlfSanitized()); _st($1)._theClass_(self._theClass()); _st($1)._arguments_(_st(aNode)._arguments()); _st($1)._selector_(_st(aNode)._selector()); _st($1)._messageSends_(_st(aNode)._messageSends()); _st($1)._superSends_(_st(aNode)._superSends()); _st($1)._classReferences_(_st(aNode)._classReferences()); _st($1)._scope_(_st(aNode)._scope()); $2=_st($1)._yourself(); self._method_($2); _st(_st(_st(aNode)._scope())._temps())._do_((function(each){ return smalltalk.withContext(function($ctx2) { $3=_st($IRTempDeclaration())._new(); _st($3)._name_(_st(each)._name()); _st($3)._scope_(_st(aNode)._scope()); $4=_st($3)._yourself(); return _st(self._method())._add_($4); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self._method())._add_(self._visit_(each)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $5=_st(_st(aNode)._scope())._hasLocalReturn(); if(! smalltalk.assert($5)){ $6=_st($IRVariable())._new(); _st($6)._variable_(_st(_st(_st(aNode)._scope())._pseudoVars())._at_("self")); $7=_st($6)._yourself(); _st(_st(self._method())._add_(_st($IRReturn())._new()))._add_($7); }; $8=self._method(); return $8; }, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitMethodNode: aNode\x0a\x0a\x09self method: (IRMethod new\x0a\x09\x09source: self source crlfSanitized;\x0a\x09\x09theClass: self theClass;\x0a\x09\x09arguments: aNode arguments;\x0a\x09\x09selector: aNode selector;\x0a\x09\x09messageSends: aNode messageSends;\x0a\x09\x09superSends: aNode superSends;\x0a\x09\x09classReferences: aNode classReferences;\x0a\x09\x09scope: aNode scope;\x0a\x09\x09yourself).\x0a\x0a\x09aNode scope temps do: [ :each |\x0a\x09\x09self method add: (IRTempDeclaration new\x0a\x09\x09\x09name: each name;\x0a\x09\x09\x09scope: aNode scope;\x0a\x09\x09\x09yourself) ].\x0a\x0a\x09aNode nodes do: [ :each | self method add: (self visit: each) ].\x0a\x0a\x09aNode scope hasLocalReturn ifFalse: [\x0a\x09\x09(self method add: IRReturn new) add: (IRVariable new\x0a\x09\x09\x09variable: (aNode scope pseudoVars at: 'self');\x0a\x09\x09\x09yourself) ].\x0a\x0a\x09^ self method", messageSends: ["method:", "source:", "crlfSanitized", "source", "new", "theClass:", "theClass", "arguments:", "arguments", "selector:", "selector", "messageSends:", "messageSends", "superSends:", "superSends", "classReferences:", "classReferences", "scope:", "scope", "yourself", "do:", "add:", "name:", "name", "method", "temps", "visit:", "nodes", "ifFalse:", "variable:", "at:", "pseudoVars", "hasLocalReturn"], referencedClasses: ["IRMethod", "IRTempDeclaration", "IRVariable", "IRReturn"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitReturnNode:", category: 'visiting', fn: function (aNode){ var self=this; var return_; function $IRNonLocalReturn(){return smalltalk.IRNonLocalReturn||(typeof IRNonLocalReturn=="undefined"?nil:IRNonLocalReturn)} function $IRReturn(){return smalltalk.IRReturn||(typeof IRReturn=="undefined"?nil:IRReturn)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(aNode)._nonLocalReturn(); if(smalltalk.assert($1)){ return_=_st($IRNonLocalReturn())._new(); } else { return_=_st($IRReturn())._new(); }; _st(return_)._scope_(_st(aNode)._scope()); _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(return_)._add_(self._alias_(each)); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $2=return_; return $2; }, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode,return_:return_},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitReturnNode: aNode\x0a\x09| return |\x0a\x09return := aNode nonLocalReturn\x0a\x09\x09ifTrue: [ IRNonLocalReturn new ]\x0a\x09\x09ifFalse: [ IRReturn new ].\x0a\x09return scope: aNode scope.\x0a\x09aNode nodes do: [ :each |\x0a\x09\x09return add: (self alias: each) ].\x0a\x09^ return", messageSends: ["ifTrue:ifFalse:", "new", "nonLocalReturn", "scope:", "scope", "do:", "add:", "alias:", "nodes"], referencedClasses: ["IRNonLocalReturn", "IRReturn"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitSendNode:", category: 'visiting', fn: function (aNode){ var self=this; var send,all,receiver,arguments; function $IRSend(){return smalltalk.IRSend||(typeof IRSend=="undefined"?nil:IRSend)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; send=_st($IRSend())._new(); $1=send; _st($1)._selector_(_st(aNode)._selector()); $2=_st($1)._index_(_st(aNode)._index()); $3=_st(aNode)._superSend(); if(smalltalk.assert($3)){ _st(send)._classSend_(_st(self._theClass())._superclass()); }; all=self._aliasTemporally_(_st([_st(aNode)._receiver()]).__comma(_st(aNode)._arguments())); receiver=_st(all)._first(); arguments=_st(all)._allButFirst(); _st(send)._add_(receiver); _st(arguments)._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(send)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $4=send; return $4; }, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode,send:send,all:all,receiver:receiver,arguments:arguments},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitSendNode: aNode\x0a\x09| send all receiver arguments |\x0a\x09send := IRSend new.\x0a\x09send\x0a\x09\x09selector: aNode selector;\x0a\x09\x09index: aNode index.\x0a\x09aNode superSend ifTrue: [ send classSend: self theClass superclass ].\x0a\x09\x0a\x09all := self aliasTemporally: { aNode receiver }, aNode arguments.\x0a\x09receiver := all first.\x0a\x09arguments := all allButFirst.\x0a\x0a\x09send add: receiver.\x0a\x09arguments do: [ :each | send add: each ].\x0a\x0a\x09^ send", messageSends: ["new", "selector:", "selector", "index:", "index", "ifTrue:", "classSend:", "superclass", "theClass", "superSend", "aliasTemporally:", ",", "arguments", "receiver", "first", "allButFirst", "add:", "do:"], referencedClasses: ["IRSend"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitSequenceNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRSequence(){return smalltalk.IRSequence||(typeof IRSequence=="undefined"?nil:IRSequence)} return smalltalk.withContext(function($ctx1) { var $2,$1; $1=self._withSequence_do_(_st($IRSequence())._new(),(function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(aNode)._nodes())._do_((function(each){ var instruction; return smalltalk.withContext(function($ctx3) { instruction=self._visit_(each); instruction; $2=_st(instruction)._isVariable(); if(! smalltalk.assert($2)){ return _st(self._sequence())._add_(instruction); }; }, function($ctx3) {$ctx3.fillBlock({each:each,instruction:instruction},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitSequenceNode: aNode\x0a\x09^ self\x0a\x09\x09withSequence: IRSequence new\x0a\x09\x09do: [\x0a\x09\x09\x09aNode nodes do: [ :each | | instruction |\x0a\x09\x09\x09\x09instruction := self visit: each.\x0a\x09\x09\x09\x09instruction isVariable ifFalse: [\x0a\x09\x09\x09\x09\x09self sequence add: instruction ]]]", messageSends: ["withSequence:do:", "new", "do:", "visit:", "ifFalse:", "add:", "sequence", "isVariable", "nodes"], referencedClasses: ["IRSequence"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitValueNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRValue(){return smalltalk.IRValue||(typeof IRValue=="undefined"?nil:IRValue)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRValue())._new(); _st($2)._value_(_st(aNode)._value()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"visitValueNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitValueNode: aNode\x0a\x09^ IRValue new\x0a\x09\x09value: aNode value;\x0a\x09\x09yourself", messageSends: ["value:", "value", "new", "yourself"], referencedClasses: ["IRValue"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitVariableNode:", category: 'visiting', fn: function (aNode){ var self=this; function $IRVariable(){return smalltalk.IRVariable||(typeof IRVariable=="undefined"?nil:IRVariable)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRVariable())._new(); _st($2)._variable_(_st(aNode)._binding()); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},smalltalk.IRASTTranslator)})}, args: ["aNode"], source: "visitVariableNode: aNode\x0a\x09^ IRVariable new\x0a\x09\x09variable: aNode binding;\x0a\x09\x09yourself", messageSends: ["variable:", "binding", "new", "yourself"], referencedClasses: ["IRVariable"] }), smalltalk.IRASTTranslator); smalltalk.addMethod( smalltalk.method({ selector: "withSequence:do:", category: 'accessing', fn: function (aSequence,aBlock){ var self=this; var outerSequence; return smalltalk.withContext(function($ctx1) { var $1; outerSequence=self._sequence(); self._sequence_(aSequence); _st(aBlock)._value(); self._sequence_(outerSequence); $1=aSequence; return $1; }, function($ctx1) {$ctx1.fill(self,"withSequence:do:",{aSequence:aSequence,aBlock:aBlock,outerSequence:outerSequence},smalltalk.IRASTTranslator)})}, args: ["aSequence", "aBlock"], source: "withSequence: aSequence do: aBlock\x0a\x09| outerSequence |\x0a\x09outerSequence := self sequence.\x0a\x09self sequence: aSequence.\x0a\x09aBlock value.\x0a\x09self sequence: outerSequence.\x0a\x09^ aSequence", messageSends: ["sequence", "sequence:", "value"], referencedClasses: [] }), smalltalk.IRASTTranslator); smalltalk.addClass('IRInstruction', smalltalk.Object, ['parent', 'instructions'], 'Compiler-IR'); smalltalk.IRInstruction.comment="I am the abstract root class of the IR (intermediate representation) instructions class hierarchy.\x0aThe IR graph is used to emit JavaScript code using a JSStream."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRInstruction_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInstruction)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRInstruction: self", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "add:", category: 'building', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(anObject)._parent_(self); $1=_st(self._instructions())._add_(anObject); return $1; }, function($ctx1) {$ctx1.fill(self,"add:",{anObject:anObject},smalltalk.IRInstruction)})}, args: ["anObject"], source: "add: anObject\x0a\x09anObject parent: self.\x0a\x09^ self instructions add: anObject", messageSends: ["parent:", "add:", "instructions"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "canBeAssigned", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"canBeAssigned",{},smalltalk.IRInstruction)})}, args: [], source: "canBeAssigned\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "instructions", category: 'accessing', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@instructions"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@instructions"]=_st($OrderedCollection())._new(); $1=self["@instructions"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"instructions",{},smalltalk.IRInstruction)})}, args: [], source: "instructions\x0a\x09^ instructions ifNil: [ instructions := OrderedCollection new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isClosure", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isClosure",{},smalltalk.IRInstruction)})}, args: [], source: "isClosure\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInstruction)})}, args: [], source: "isInlined\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isLocalReturn",{},smalltalk.IRInstruction)})}, args: [], source: "isLocalReturn\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isMethod", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isMethod",{},smalltalk.IRInstruction)})}, args: [], source: "isMethod\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isReturn",{},smalltalk.IRInstruction)})}, args: [], source: "isReturn\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isSend", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isSend",{},smalltalk.IRInstruction)})}, args: [], source: "isSend\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isSequence", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isSequence",{},smalltalk.IRInstruction)})}, args: [], source: "isSequence\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isTempDeclaration", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isTempDeclaration",{},smalltalk.IRInstruction)})}, args: [], source: "isTempDeclaration\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "isVariable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isVariable",{},smalltalk.IRInstruction)})}, args: [], source: "isVariable\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._parent())._method(); return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.IRInstruction)})}, args: [], source: "method\x0a\x09^ self parent method", messageSends: ["method", "parent"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "needsBoxingAsReceiver", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"needsBoxingAsReceiver",{},smalltalk.IRInstruction)})}, args: [], source: "needsBoxingAsReceiver\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "parent", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@parent"]; return $1; }, function($ctx1) {$ctx1.fill(self,"parent",{},smalltalk.IRInstruction)})}, args: [], source: "parent\x0a\x09^ parent", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "parent:", category: 'accessing', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { self["@parent"]=anIRInstruction; return self}, function($ctx1) {$ctx1.fill(self,"parent:",{anIRInstruction:anIRInstruction},smalltalk.IRInstruction)})}, args: ["anIRInstruction"], source: "parent: anIRInstruction\x0a\x09parent := anIRInstruction", messageSends: [], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "remove", category: 'building', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._parent())._remove_(self); return self}, function($ctx1) {$ctx1.fill(self,"remove",{},smalltalk.IRInstruction)})}, args: [], source: "remove\x0a\x09self parent remove: self", messageSends: ["remove:", "parent"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "remove:", category: 'building', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._instructions())._remove_(anIRInstruction); return self}, function($ctx1) {$ctx1.fill(self,"remove:",{anIRInstruction:anIRInstruction},smalltalk.IRInstruction)})}, args: ["anIRInstruction"], source: "remove: anIRInstruction\x0a\x09self instructions remove: anIRInstruction", messageSends: ["remove:", "instructions"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "replace:with:", category: 'building', fn: function (anIRInstruction,anotherIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { _st(anotherIRInstruction)._parent_(self); _st(self._instructions())._at_put_(_st(self._instructions())._indexOf_(anIRInstruction),anotherIRInstruction); return self}, function($ctx1) {$ctx1.fill(self,"replace:with:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},smalltalk.IRInstruction)})}, args: ["anIRInstruction", "anotherIRInstruction"], source: "replace: anIRInstruction with: anotherIRInstruction\x0a\x09anotherIRInstruction parent: self.\x0a\x09self instructions\x0a\x09\x09at: (self instructions indexOf: anIRInstruction)\x0a\x09\x09put: anotherIRInstruction", messageSends: ["parent:", "at:put:", "indexOf:", "instructions"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "replaceWith:", category: 'building', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._parent())._replace_with_(self,anIRInstruction); return self}, function($ctx1) {$ctx1.fill(self,"replaceWith:",{anIRInstruction:anIRInstruction},smalltalk.IRInstruction)})}, args: ["anIRInstruction"], source: "replaceWith: anIRInstruction\x0a\x09self parent replace: self with: anIRInstruction", messageSends: ["replace:with:", "parent"], referencedClasses: [] }), smalltalk.IRInstruction); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (aBuilder){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._builder_(aBuilder); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{aBuilder:aBuilder},smalltalk.IRInstruction.klass)})}, args: ["aBuilder"], source: "on: aBuilder\x0a\x09^ self new\x0a\x09\x09builder: aBuilder;\x0a\x09\x09yourself", messageSends: ["builder:", "new", "yourself"], referencedClasses: [] }), smalltalk.IRInstruction.klass); smalltalk.addClass('IRAssignment', smalltalk.IRInstruction, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRAssignment_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRAssignment)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRAssignment: self", messageSends: ["visitIRAssignment:"], referencedClasses: [] }), smalltalk.IRAssignment); smalltalk.addClass('IRDynamicArray', smalltalk.IRInstruction, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRDynamicArray_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRDynamicArray)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRDynamicArray: self", messageSends: ["visitIRDynamicArray:"], referencedClasses: [] }), smalltalk.IRDynamicArray); smalltalk.addClass('IRDynamicDictionary', smalltalk.IRInstruction, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRDynamicDictionary_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRDynamicDictionary)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRDynamicDictionary: self", messageSends: ["visitIRDynamicDictionary:"], referencedClasses: [] }), smalltalk.IRDynamicDictionary); smalltalk.addClass('IRScopedInstruction', smalltalk.IRInstruction, ['scope'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.IRScopedInstruction)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.IRScopedInstruction); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aScope:aScope},smalltalk.IRScopedInstruction)})}, args: ["aScope"], source: "scope: aScope\x0a\x09scope := aScope", messageSends: [], referencedClasses: [] }), smalltalk.IRScopedInstruction); smalltalk.addClass('IRClosureInstruction', smalltalk.IRScopedInstruction, ['arguments'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "arguments", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@arguments"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=[]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"arguments",{},smalltalk.IRClosureInstruction)})}, args: [], source: "arguments\x0a\x09^ arguments ifNil: [ #() ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.IRClosureInstruction); smalltalk.addMethod( smalltalk.method({ selector: "arguments:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@arguments"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"arguments:",{aCollection:aCollection},smalltalk.IRClosureInstruction)})}, args: ["aCollection"], source: "arguments: aCollection\x0a\x09arguments := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.IRClosureInstruction); smalltalk.addMethod( smalltalk.method({ selector: "locals", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st(self._arguments())._copy(); _st($2)._addAll_(_st(self._tempDeclarations())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._name(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}))); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"locals",{},smalltalk.IRClosureInstruction)})}, args: [], source: "locals\x0a\x09^ self arguments copy\x0a\x09\x09addAll: (self tempDeclarations collect: [ :each | each name ]);\x0a\x09\x09yourself", messageSends: ["addAll:", "collect:", "name", "tempDeclarations", "copy", "arguments", "yourself"], referencedClasses: [] }), smalltalk.IRClosureInstruction); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.IRClosureInstruction.superclass.fn.prototype._scope_.apply(_st(self), [aScope]); _st(aScope)._instruction_(self); return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aScope:aScope},smalltalk.IRClosureInstruction)})}, args: ["aScope"], source: "scope: aScope\x0a\x09super scope: aScope.\x0a\x09aScope instruction: self", messageSends: ["scope:", "instruction:"], referencedClasses: [] }), smalltalk.IRClosureInstruction); smalltalk.addMethod( smalltalk.method({ selector: "tempDeclarations", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._instructions())._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._isTempDeclaration(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"tempDeclarations",{},smalltalk.IRClosureInstruction)})}, args: [], source: "tempDeclarations\x0a\x09^ self instructions select: [ :each |\x0a\x09\x09each isTempDeclaration ]", messageSends: ["select:", "isTempDeclaration", "instructions"], referencedClasses: [] }), smalltalk.IRClosureInstruction); smalltalk.addClass('IRClosure', smalltalk.IRClosureInstruction, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRClosure_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRClosure)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRClosure: self", messageSends: ["visitIRClosure:"], referencedClasses: [] }), smalltalk.IRClosure); smalltalk.addMethod( smalltalk.method({ selector: "isClosure", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isClosure",{},smalltalk.IRClosure)})}, args: [], source: "isClosure\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRClosure); smalltalk.addMethod( smalltalk.method({ selector: "sequence", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._instructions())._last(); return $1; }, function($ctx1) {$ctx1.fill(self,"sequence",{},smalltalk.IRClosure)})}, args: [], source: "sequence\x0a\x09^ self instructions last", messageSends: ["last", "instructions"], referencedClasses: [] }), smalltalk.IRClosure); smalltalk.addClass('IRMethod', smalltalk.IRClosureInstruction, ['theClass', 'source', 'selector', 'classReferences', 'messageSends', 'superSends', 'internalVariables'], 'Compiler-IR'); smalltalk.IRMethod.comment="I am a method instruction"; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRMethod_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRMethod)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRMethod: self", messageSends: ["visitIRMethod:"], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "classReferences", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@classReferences"]; return $1; }, function($ctx1) {$ctx1.fill(self,"classReferences",{},smalltalk.IRMethod)})}, args: [], source: "classReferences\x0a\x09^ classReferences", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "classReferences:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@classReferences"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"classReferences:",{aCollection:aCollection},smalltalk.IRMethod)})}, args: ["aCollection"], source: "classReferences: aCollection\x0a\x09classReferences := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "internalVariables", category: 'accessing', fn: function (){ var self=this; function $Set(){return smalltalk.Set||(typeof Set=="undefined"?nil:Set)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@internalVariables"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@internalVariables"]=_st($Set())._new(); $1=self["@internalVariables"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"internalVariables",{},smalltalk.IRMethod)})}, args: [], source: "internalVariables\x0a\x09^ internalVariables ifNil: [ internalVariables := Set new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Set"] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "isMethod", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isMethod",{},smalltalk.IRMethod)})}, args: [], source: "isMethod\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "messageSends", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@messageSends"]; return $1; }, function($ctx1) {$ctx1.fill(self,"messageSends",{},smalltalk.IRMethod)})}, args: [], source: "messageSends\x0a\x09^ messageSends", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "messageSends:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@messageSends"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"messageSends:",{aCollection:aCollection},smalltalk.IRMethod)})}, args: ["aCollection"], source: "messageSends: aCollection\x0a\x09messageSends := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.IRMethod)})}, args: [], source: "method\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@selector"]; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.IRMethod)})}, args: [], source: "selector\x0a\x09^ selector", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@selector"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.IRMethod)})}, args: ["aString"], source: "selector: aString\x0a\x09selector := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@source"]; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.IRMethod)})}, args: [], source: "source\x0a\x09^ source", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.IRMethod)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "superSends", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@superSends"]; return $1; }, function($ctx1) {$ctx1.fill(self,"superSends",{},smalltalk.IRMethod)})}, args: [], source: "superSends\x0a\x09^ superSends", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "superSends:", category: 'accessing', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { self["@superSends"]=aCollection; return self}, function($ctx1) {$ctx1.fill(self,"superSends:",{aCollection:aCollection},smalltalk.IRMethod)})}, args: ["aCollection"], source: "superSends: aCollection\x0a\x09superSends := aCollection", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.IRMethod)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.IRMethod)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.IRMethod); smalltalk.addClass('IRReturn', smalltalk.IRScopedInstruction, [], 'Compiler-IR'); smalltalk.IRReturn.comment="I am a local return instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRReturn_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRReturn)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRReturn: self", messageSends: ["visitIRReturn:"], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addMethod( smalltalk.method({ selector: "canBeAssigned", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"canBeAssigned",{},smalltalk.IRReturn)})}, args: [], source: "canBeAssigned\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addMethod( smalltalk.method({ selector: "isBlockReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isBlockReturn",{},smalltalk.IRReturn)})}, args: [], source: "isBlockReturn\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addMethod( smalltalk.method({ selector: "isLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isLocalReturn",{},smalltalk.IRReturn)})}, args: [], source: "isLocalReturn\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addMethod( smalltalk.method({ selector: "isNonLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._isLocalReturn())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"isNonLocalReturn",{},smalltalk.IRReturn)})}, args: [], source: "isNonLocalReturn\x0a\x09^ self isLocalReturn not", messageSends: ["not", "isLocalReturn"], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addMethod( smalltalk.method({ selector: "isReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isReturn",{},smalltalk.IRReturn)})}, args: [], source: "isReturn\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRReturn); smalltalk.addClass('IRBlockReturn', smalltalk.IRReturn, [], 'Compiler-IR'); smalltalk.IRBlockReturn.comment="Smalltalk blocks return their last statement. I am a implicit block return instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRBlockReturn_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRBlockReturn)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRBlockReturn: self", messageSends: ["visitIRBlockReturn:"], referencedClasses: [] }), smalltalk.IRBlockReturn); smalltalk.addMethod( smalltalk.method({ selector: "isBlockReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isBlockReturn",{},smalltalk.IRBlockReturn)})}, args: [], source: "isBlockReturn\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRBlockReturn); smalltalk.addClass('IRNonLocalReturn', smalltalk.IRReturn, [], 'Compiler-IR'); smalltalk.IRNonLocalReturn.comment="I am a non local return instruction.\x0aNon local returns are handled using a try/catch JavaScript statement.\x0a\x0aSee `IRNonLocalReturnHandling` class."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRNonLocalReturn_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRNonLocalReturn)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRNonLocalReturn: self", messageSends: ["visitIRNonLocalReturn:"], referencedClasses: [] }), smalltalk.IRNonLocalReturn); smalltalk.addMethod( smalltalk.method({ selector: "isLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isLocalReturn",{},smalltalk.IRNonLocalReturn)})}, args: [], source: "isLocalReturn\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRNonLocalReturn); smalltalk.addClass('IRTempDeclaration', smalltalk.IRScopedInstruction, ['name'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRTempDeclaration_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRTempDeclaration)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRTempDeclaration: self", messageSends: ["visitIRTempDeclaration:"], referencedClasses: [] }), smalltalk.IRTempDeclaration); smalltalk.addMethod( smalltalk.method({ selector: "isTempDeclaration", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isTempDeclaration",{},smalltalk.IRTempDeclaration)})}, args: [], source: "isTempDeclaration\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRTempDeclaration); smalltalk.addMethod( smalltalk.method({ selector: "name", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@name"]; return $1; }, function($ctx1) {$ctx1.fill(self,"name",{},smalltalk.IRTempDeclaration)})}, args: [], source: "name\x0a\x09^ name", messageSends: [], referencedClasses: [] }), smalltalk.IRTempDeclaration); smalltalk.addMethod( smalltalk.method({ selector: "name:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@name"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"name:",{aString:aString},smalltalk.IRTempDeclaration)})}, args: ["aString"], source: "name: aString\x0a\x09name := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRTempDeclaration); smalltalk.addClass('IRSend', smalltalk.IRInstruction, ['selector', 'classSend', 'index'], 'Compiler-IR'); smalltalk.IRSend.comment="I am a message send instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRSend_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRSend)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRSend: self", messageSends: ["visitIRSend:"], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "classSend", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@classSend"]; return $1; }, function($ctx1) {$ctx1.fill(self,"classSend",{},smalltalk.IRSend)})}, args: [], source: "classSend\x0a\x09^ classSend", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "classSend:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@classSend"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"classSend:",{aClass:aClass},smalltalk.IRSend)})}, args: ["aClass"], source: "classSend: aClass\x0a\x09classSend := aClass", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "index", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@index"]; return $1; }, function($ctx1) {$ctx1.fill(self,"index",{},smalltalk.IRSend)})}, args: [], source: "index\x0a\x09^ index", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "index:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@index"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"index:",{anInteger:anInteger},smalltalk.IRSend)})}, args: ["anInteger"], source: "index: anInteger\x0a\x09index := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "isSend", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSend",{},smalltalk.IRSend)})}, args: [], source: "isSend\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@selector"]; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.IRSend)})}, args: [], source: "selector\x0a\x09^ selector", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addMethod( smalltalk.method({ selector: "selector:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@selector"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"selector:",{aString:aString},smalltalk.IRSend)})}, args: ["aString"], source: "selector: aString\x0a\x09selector := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRSend); smalltalk.addClass('IRSequence', smalltalk.IRInstruction, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRSequence_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRSequence)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRSequence: self", messageSends: ["visitIRSequence:"], referencedClasses: [] }), smalltalk.IRSequence); smalltalk.addMethod( smalltalk.method({ selector: "isSequence", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSequence",{},smalltalk.IRSequence)})}, args: [], source: "isSequence\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRSequence); smalltalk.addClass('IRBlockSequence', smalltalk.IRSequence, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRBlockSequence_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRBlockSequence)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRBlockSequence: self", messageSends: ["visitIRBlockSequence:"], referencedClasses: [] }), smalltalk.IRBlockSequence); smalltalk.addClass('IRValue', smalltalk.IRInstruction, ['value'], 'Compiler-IR'); smalltalk.IRValue.comment="I am the simplest possible instruction. I represent a value."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRValue_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRValue)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRValue: self", messageSends: ["visitIRValue:"], referencedClasses: [] }), smalltalk.IRValue); smalltalk.addMethod( smalltalk.method({ selector: "needsBoxingAsReceiver", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"needsBoxingAsReceiver",{},smalltalk.IRValue)})}, args: [], source: "needsBoxingAsReceiver\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.IRValue); smalltalk.addMethod( smalltalk.method({ selector: "value", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@value"]; return $1; }, function($ctx1) {$ctx1.fill(self,"value",{},smalltalk.IRValue)})}, args: [], source: "value\x0a\x09^value", messageSends: [], referencedClasses: [] }), smalltalk.IRValue); smalltalk.addMethod( smalltalk.method({ selector: "value:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@value"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"value:",{aString:aString},smalltalk.IRValue)})}, args: ["aString"], source: "value: aString\x0a\x09value := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRValue); smalltalk.addClass('IRVariable', smalltalk.IRInstruction, ['variable'], 'Compiler-IR'); smalltalk.IRVariable.comment="I am a variable instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRVariable_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRVariable)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRVariable: self", messageSends: ["visitIRVariable:"], referencedClasses: [] }), smalltalk.IRVariable); smalltalk.addMethod( smalltalk.method({ selector: "isVariable", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isVariable",{},smalltalk.IRVariable)})}, args: [], source: "isVariable\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRVariable); smalltalk.addMethod( smalltalk.method({ selector: "needsBoxingAsReceiver", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._variable())._isPseudoVar())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"needsBoxingAsReceiver",{},smalltalk.IRVariable)})}, args: [], source: "needsBoxingAsReceiver\x0a\x09^ self variable isPseudoVar not", messageSends: ["not", "isPseudoVar", "variable"], referencedClasses: [] }), smalltalk.IRVariable); smalltalk.addMethod( smalltalk.method({ selector: "variable", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@variable"]; return $1; }, function($ctx1) {$ctx1.fill(self,"variable",{},smalltalk.IRVariable)})}, args: [], source: "variable\x0a\x09^ variable", messageSends: [], referencedClasses: [] }), smalltalk.IRVariable); smalltalk.addMethod( smalltalk.method({ selector: "variable:", category: 'accessing', fn: function (aScopeVariable){ var self=this; return smalltalk.withContext(function($ctx1) { self["@variable"]=aScopeVariable; return self}, function($ctx1) {$ctx1.fill(self,"variable:",{aScopeVariable:aScopeVariable},smalltalk.IRVariable)})}, args: ["aScopeVariable"], source: "variable: aScopeVariable\x0a\x09variable := aScopeVariable", messageSends: [], referencedClasses: [] }), smalltalk.IRVariable); smalltalk.addClass('IRVerbatim', smalltalk.IRInstruction, ['source'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRVerbatim_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRVerbatim)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRVerbatim: self", messageSends: ["visitIRVerbatim:"], referencedClasses: [] }), smalltalk.IRVerbatim); smalltalk.addMethod( smalltalk.method({ selector: "source", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@source"]; return $1; }, function($ctx1) {$ctx1.fill(self,"source",{},smalltalk.IRVerbatim)})}, args: [], source: "source\x0a\x09^ source", messageSends: [], referencedClasses: [] }), smalltalk.IRVerbatim); smalltalk.addMethod( smalltalk.method({ selector: "source:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@source"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"source:",{aString:aString},smalltalk.IRVerbatim)})}, args: ["aString"], source: "source: aString\x0a\x09source := aString", messageSends: [], referencedClasses: [] }), smalltalk.IRVerbatim); smalltalk.addClass('IRVisitor', smalltalk.Object, [], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "visit:", category: 'visiting', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anIRInstruction)._accept_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"visit:",{anIRInstruction:anIRInstruction},smalltalk.IRVisitor)})}, args: ["anIRInstruction"], source: "visit: anIRInstruction\x0a\x09^ anIRInstruction accept: self", messageSends: ["accept:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRAssignment:", category: 'visiting', fn: function (anIRAssignment){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRAssignment); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},smalltalk.IRVisitor)})}, args: ["anIRAssignment"], source: "visitIRAssignment: anIRAssignment\x0a\x09^ self visitIRInstruction: anIRAssignment", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRBlockReturn:", category: 'visiting', fn: function (anIRBlockReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRReturn_(anIRBlockReturn); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRBlockReturn:",{anIRBlockReturn:anIRBlockReturn},smalltalk.IRVisitor)})}, args: ["anIRBlockReturn"], source: "visitIRBlockReturn: anIRBlockReturn\x0a\x09^ self visitIRReturn: anIRBlockReturn", messageSends: ["visitIRReturn:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRBlockSequence:", category: 'visiting', fn: function (anIRBlockSequence){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRSequence_(anIRBlockSequence); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRBlockSequence:",{anIRBlockSequence:anIRBlockSequence},smalltalk.IRVisitor)})}, args: ["anIRBlockSequence"], source: "visitIRBlockSequence: anIRBlockSequence\x0a\x09^ self visitIRSequence: anIRBlockSequence", messageSends: ["visitIRSequence:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRClosure:", category: 'visiting', fn: function (anIRClosure){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRClosure); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRClosure:",{anIRClosure:anIRClosure},smalltalk.IRVisitor)})}, args: ["anIRClosure"], source: "visitIRClosure: anIRClosure\x0a\x09^ self visitIRInstruction: anIRClosure", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRDynamicArray:", category: 'visiting', fn: function (anIRDynamicArray){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRDynamicArray); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicArray:",{anIRDynamicArray:anIRDynamicArray},smalltalk.IRVisitor)})}, args: ["anIRDynamicArray"], source: "visitIRDynamicArray: anIRDynamicArray\x0a\x09^ self visitIRInstruction: anIRDynamicArray", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRDynamicDictionary:", category: 'visiting', fn: function (anIRDynamicDictionary){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRDynamicDictionary); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRDynamicDictionary:",{anIRDynamicDictionary:anIRDynamicDictionary},smalltalk.IRVisitor)})}, args: ["anIRDynamicDictionary"], source: "visitIRDynamicDictionary: anIRDynamicDictionary\x0a\x09^ self visitIRInstruction: anIRDynamicDictionary", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedClosure:", category: 'visiting', fn: function (anIRInlinedClosure){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRClosure_(anIRInlinedClosure); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedClosure:",{anIRInlinedClosure:anIRInlinedClosure},smalltalk.IRVisitor)})}, args: ["anIRInlinedClosure"], source: "visitIRInlinedClosure: anIRInlinedClosure\x0a\x09^ self visitIRClosure: anIRInlinedClosure", messageSends: ["visitIRClosure:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedSequence:", category: 'visiting', fn: function (anIRInlinedSequence){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRSequence_(anIRInlinedSequence); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRInlinedSequence:",{anIRInlinedSequence:anIRInlinedSequence},smalltalk.IRVisitor)})}, args: ["anIRInlinedSequence"], source: "visitIRInlinedSequence: anIRInlinedSequence\x0a\x09^ self visitIRSequence: anIRInlinedSequence", messageSends: ["visitIRSequence:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInstruction:", category: 'visiting', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(_st(anIRInstruction)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=anIRInstruction; return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRInstruction:",{anIRInstruction:anIRInstruction},smalltalk.IRVisitor)})}, args: ["anIRInstruction"], source: "visitIRInstruction: anIRInstruction\x0a\x09anIRInstruction instructions do: [ :each | self visit: each ].\x0a\x09^ anIRInstruction", messageSends: ["do:", "visit:", "instructions"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRMethod:", category: 'visiting', fn: function (anIRMethod){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRMethod); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRMethod:",{anIRMethod:anIRMethod},smalltalk.IRVisitor)})}, args: ["anIRMethod"], source: "visitIRMethod: anIRMethod\x0a\x09^ self visitIRInstruction: anIRMethod", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRNonLocalReturn:", category: 'visiting', fn: function (anIRNonLocalReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRNonLocalReturn); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn},smalltalk.IRVisitor)})}, args: ["anIRNonLocalReturn"], source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09^ self visitIRInstruction: anIRNonLocalReturn", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRNonLocalReturnHandling:", category: 'visiting', fn: function (anIRNonLocalReturnHandling){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRNonLocalReturnHandling); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturnHandling:",{anIRNonLocalReturnHandling:anIRNonLocalReturnHandling},smalltalk.IRVisitor)})}, args: ["anIRNonLocalReturnHandling"], source: "visitIRNonLocalReturnHandling: anIRNonLocalReturnHandling\x0a\x09^ self visitIRInstruction: anIRNonLocalReturnHandling", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRReturn:", category: 'visiting', fn: function (anIRReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRReturn); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},smalltalk.IRVisitor)})}, args: ["anIRReturn"], source: "visitIRReturn: anIRReturn\x0a\x09^ self visitIRInstruction: anIRReturn", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRSend:", category: 'visiting', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRSend); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend},smalltalk.IRVisitor)})}, args: ["anIRSend"], source: "visitIRSend: anIRSend\x0a\x09^ self visitIRInstruction: anIRSend", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRSequence:", category: 'visiting', fn: function (anIRSequence){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRSequence); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRSequence:",{anIRSequence:anIRSequence},smalltalk.IRVisitor)})}, args: ["anIRSequence"], source: "visitIRSequence: anIRSequence\x0a\x09^ self visitIRInstruction: anIRSequence", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRTempDeclaration:", category: 'visiting', fn: function (anIRTempDeclaration){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRTempDeclaration); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRTempDeclaration:",{anIRTempDeclaration:anIRTempDeclaration},smalltalk.IRVisitor)})}, args: ["anIRTempDeclaration"], source: "visitIRTempDeclaration: anIRTempDeclaration\x0a\x09^ self visitIRInstruction: anIRTempDeclaration", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRValue:", category: 'visiting', fn: function (anIRValue){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRValue); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRValue:",{anIRValue:anIRValue},smalltalk.IRVisitor)})}, args: ["anIRValue"], source: "visitIRValue: anIRValue\x0a\x09^ self visitIRInstruction: anIRValue", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRVariable:", category: 'visiting', fn: function (anIRVariable){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRVariable); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRVariable:",{anIRVariable:anIRVariable},smalltalk.IRVisitor)})}, args: ["anIRVariable"], source: "visitIRVariable: anIRVariable\x0a\x09^ self visitIRInstruction: anIRVariable", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitIRVerbatim:", category: 'visiting', fn: function (anIRVerbatim){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._visitIRInstruction_(anIRVerbatim); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRVerbatim:",{anIRVerbatim:anIRVerbatim},smalltalk.IRVisitor)})}, args: ["anIRVerbatim"], source: "visitIRVerbatim: anIRVerbatim\x0a\x09^ self visitIRInstruction: anIRVerbatim", messageSends: ["visitIRInstruction:"], referencedClasses: [] }), smalltalk.IRVisitor); smalltalk.addClass('IRJSTranslator', smalltalk.IRVisitor, ['stream', 'currentClass'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "contents", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._stream())._contents(); return $1; }, function($ctx1) {$ctx1.fill(self,"contents",{},smalltalk.IRJSTranslator)})}, args: [], source: "contents\x0a\x09^ self stream contents", messageSends: ["contents", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "currentClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"currentClass",{},smalltalk.IRJSTranslator)})}, args: [], source: "currentClass\x0a\x09^ currentClass", messageSends: [], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "currentClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@currentClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"currentClass:",{aClass:aClass},smalltalk.IRJSTranslator)})}, args: ["aClass"], source: "currentClass: aClass\x0a\x09currentClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $JSStream(){return smalltalk.JSStream||(typeof JSStream=="undefined"?nil:JSStream)} return smalltalk.withContext(function($ctx1) { smalltalk.IRJSTranslator.superclass.fn.prototype._initialize.apply(_st(self), []); self["@stream"]=_st($JSStream())._new(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.IRJSTranslator)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09stream := JSStream new.", messageSends: ["initialize", "new"], referencedClasses: ["JSStream"] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "stream", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@stream"]; return $1; }, function($ctx1) {$ctx1.fill(self,"stream",{},smalltalk.IRJSTranslator)})}, args: [], source: "stream\x0a\x09^ stream", messageSends: [], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "stream:", category: 'accessing', fn: function (aStream){ var self=this; return smalltalk.withContext(function($ctx1) { self["@stream"]=aStream; return self}, function($ctx1) {$ctx1.fill(self,"stream:",{aStream:aStream},smalltalk.IRJSTranslator)})}, args: ["aStream"], source: "stream: aStream\x0a\x09stream := aStream", messageSends: [], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRAssignment:", category: 'visiting', fn: function (anIRAssignment){ var self=this; return smalltalk.withContext(function($ctx1) { self._visit_(_st(_st(anIRAssignment)._instructions())._first()); _st(self._stream())._nextPutAssignment(); self._visit_(_st(_st(anIRAssignment)._instructions())._last()); return self}, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},smalltalk.IRJSTranslator)})}, args: ["anIRAssignment"], source: "visitIRAssignment: anIRAssignment\x0a\x09self visit: anIRAssignment instructions first.\x0a\x09self stream nextPutAssignment.\x0a\x09self visit: anIRAssignment instructions last.", messageSends: ["visit:", "first", "instructions", "nextPutAssignment", "stream", "last"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRClosure:", category: 'visiting', fn: function (anIRClosure){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutClosureWith_arguments_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutVars_(_st(_st(anIRClosure)._tempDeclarations())._collect_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(_st(each)._name())._asVariableName(); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}))); return _st(self._stream())._nextPutBlockContextFor_during_(anIRClosure,(function(){ return smalltalk.withContext(function($ctx3) { return smalltalk.IRJSTranslator.superclass.fn.prototype._visitIRClosure_.apply(_st(self), [anIRClosure]); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),_st(anIRClosure)._arguments()); return self}, function($ctx1) {$ctx1.fill(self,"visitIRClosure:",{anIRClosure:anIRClosure},smalltalk.IRJSTranslator)})}, args: ["anIRClosure"], source: "visitIRClosure: anIRClosure\x0a\x09self stream\x0a\x09\x09nextPutClosureWith: [\x0a\x09\x09\x09self stream nextPutVars: (anIRClosure tempDeclarations collect: [ :each |\x0a\x09\x09\x09\x09\x09each name asVariableName ]).\x0a\x09\x09\x09self stream\x0a\x09\x09\x09\x09nextPutBlockContextFor: anIRClosure\x0a\x09\x09\x09\x09during: [ super visitIRClosure: anIRClosure ] ]\x0a\x09\x09arguments: anIRClosure arguments", messageSends: ["nextPutClosureWith:arguments:", "nextPutVars:", "collect:", "asVariableName", "name", "tempDeclarations", "stream", "nextPutBlockContextFor:during:", "visitIRClosure:", "arguments"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRDynamicArray:", category: 'visiting', fn: function (anIRDynamicArray){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutAll_("["); _st(_st(anIRDynamicArray)._instructions())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self["@stream"])._nextPutAll_("]"); return self}, function($ctx1) {$ctx1.fill(self,"visitIRDynamicArray:",{anIRDynamicArray:anIRDynamicArray},smalltalk.IRJSTranslator)})}, args: ["anIRDynamicArray"], source: "visitIRDynamicArray: anIRDynamicArray\x0a\x09self stream nextPutAll: '['.\x0a\x09anIRDynamicArray instructions\x0a\x09\x09do: [ :each | self visit: each ]\x0a\x09\x09separatedBy: [ self stream nextPutAll: ',' ].\x0a\x09stream nextPutAll: ']'", messageSends: ["nextPutAll:", "stream", "do:separatedBy:", "visit:", "instructions"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRDynamicDictionary:", category: 'visiting', fn: function (anIRDynamicDictionary){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutAll_("smalltalk.HashedCollection._from_(["); _st(_st(anIRDynamicDictionary)._instructions())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self._stream())._nextPutAll_("])"); return self}, function($ctx1) {$ctx1.fill(self,"visitIRDynamicDictionary:",{anIRDynamicDictionary:anIRDynamicDictionary},smalltalk.IRJSTranslator)})}, args: ["anIRDynamicDictionary"], source: "visitIRDynamicDictionary: anIRDynamicDictionary\x0a\x09self stream nextPutAll: 'smalltalk.HashedCollection._from_(['.\x0a\x09\x09anIRDynamicDictionary instructions\x0a\x09\x09\x09do: [ :each | self visit: each ]\x0a\x09\x09\x09separatedBy: [self stream nextPutAll: ',' ].\x0a\x09self stream nextPutAll: '])'", messageSends: ["nextPutAll:", "stream", "do:separatedBy:", "visit:", "instructions"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRMethod:", category: 'visiting', fn: function (anIRMethod){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; _st(self._stream())._nextPutMethodDeclaration_with_(anIRMethod,(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutFunctionWith_arguments_((function(){ return smalltalk.withContext(function($ctx3) { _st(self._stream())._nextPutVars_(_st(_st(anIRMethod)._tempDeclarations())._collect_((function(each){ return smalltalk.withContext(function($ctx4) { return _st(_st(each)._name())._asVariableName(); }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3)})}))); _st(_st(anIRMethod)._classReferences())._do_((function(each){ return smalltalk.withContext(function($ctx4) { return _st(self._stream())._nextPutClassRefFunction_(each); }, function($ctx4) {$ctx4.fillBlock({each:each},$ctx3)})})); return _st(self._stream())._nextPutContextFor_during_(anIRMethod,(function(){ return smalltalk.withContext(function($ctx4) { $1=_st(_st(anIRMethod)._internalVariables())._notEmpty(); if(smalltalk.assert($1)){ _st(self._stream())._nextPutVars_(_st(_st(_st(anIRMethod)._internalVariables())._asArray())._collect_((function(each){ return smalltalk.withContext(function($ctx5) { return _st(_st(each)._variable())._alias(); }, function($ctx5) {$ctx5.fillBlock({each:each},$ctx4)})}))); }; $2=_st(_st(anIRMethod)._scope())._hasNonLocalReturn(); if(smalltalk.assert($2)){ return _st(self._stream())._nextPutNonLocalReturnHandlingWith_((function(){ return smalltalk.withContext(function($ctx5) { return smalltalk.IRJSTranslator.superclass.fn.prototype._visitIRMethod_.apply(_st(self), [anIRMethod]); }, function($ctx5) {$ctx5.fillBlock({},$ctx4)})})); } else { return smalltalk.IRJSTranslator.superclass.fn.prototype._visitIRMethod_.apply(_st(self), [anIRMethod]); }; }, function($ctx4) {$ctx4.fillBlock({},$ctx3)})})); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})}),_st(anIRMethod)._arguments()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRMethod:",{anIRMethod:anIRMethod},smalltalk.IRJSTranslator)})}, args: ["anIRMethod"], source: "visitIRMethod: anIRMethod\x0a\x0a\x09self stream\x0a\x09\x09nextPutMethodDeclaration: anIRMethod\x0a\x09\x09with: [ self stream\x0a\x09\x09\x09nextPutFunctionWith: [\x0a\x09\x09\x09\x09self stream nextPutVars: (anIRMethod tempDeclarations collect: [ :each |\x0a\x09\x09\x09\x09\x09each name asVariableName ]).\x0a\x09\x09\x09\x09anIRMethod classReferences do: [ :each | self stream nextPutClassRefFunction: each ].\x0a\x09\x09\x09\x09self stream nextPutContextFor: anIRMethod during: [\x0a\x09\x09\x09\x09anIRMethod internalVariables notEmpty ifTrue: [\x0a\x09\x09\x09\x09\x09self stream nextPutVars: (anIRMethod internalVariables asArray collect: [ :each |\x0a\x09\x09\x09\x09\x09\x09each variable alias ]) ].\x0a\x09\x09\x09\x09anIRMethod scope hasNonLocalReturn\x0a\x09\x09\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09\x09\x09self stream nextPutNonLocalReturnHandlingWith: [\x0a\x09\x09\x09\x09\x09\x09\x09super visitIRMethod: anIRMethod ]]\x0a\x09\x09\x09\x09\x09ifFalse: [ super visitIRMethod: anIRMethod ]]]\x0a\x09\x09\x09arguments: anIRMethod arguments ]", messageSends: ["nextPutMethodDeclaration:with:", "nextPutFunctionWith:arguments:", "nextPutVars:", "collect:", "asVariableName", "name", "tempDeclarations", "stream", "do:", "nextPutClassRefFunction:", "classReferences", "nextPutContextFor:during:", "ifTrue:", "alias", "variable", "asArray", "internalVariables", "notEmpty", "ifTrue:ifFalse:", "nextPutNonLocalReturnHandlingWith:", "visitIRMethod:", "hasNonLocalReturn", "scope", "arguments"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRNonLocalReturn:", category: 'visiting', fn: function (anIRNonLocalReturn){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutNonLocalReturnWith_((function(){ return smalltalk.withContext(function($ctx2) { return smalltalk.IRJSTranslator.superclass.fn.prototype._visitIRNonLocalReturn_.apply(_st(self), [anIRNonLocalReturn]); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn},smalltalk.IRJSTranslator)})}, args: ["anIRNonLocalReturn"], source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09self stream nextPutNonLocalReturnWith: [\x0a\x09\x09super visitIRNonLocalReturn: anIRNonLocalReturn ]", messageSends: ["nextPutNonLocalReturnWith:", "visitIRNonLocalReturn:", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRReturn:", category: 'visiting', fn: function (anIRReturn){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutReturnWith_((function(){ return smalltalk.withContext(function($ctx2) { return smalltalk.IRJSTranslator.superclass.fn.prototype._visitIRReturn_.apply(_st(self), [anIRReturn]); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},smalltalk.IRJSTranslator)})}, args: ["anIRReturn"], source: "visitIRReturn: anIRReturn\x0a\x09self stream nextPutReturnWith: [\x0a\x09\x09super visitIRReturn: anIRReturn ]", messageSends: ["nextPutReturnWith:", "visitIRReturn:", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRSend:", category: 'visiting', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anIRSend)._classSend(); if(($receiver = $1) == nil || $receiver == undefined){ self._visitSend_(anIRSend); } else { self._visitSuperSend_(anIRSend); }; return self}, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend},smalltalk.IRJSTranslator)})}, args: ["anIRSend"], source: "visitIRSend: anIRSend\x0a\x09anIRSend classSend\x0a\x09\x09ifNil: [ self visitSend: anIRSend ]\x0a\x09\x09ifNotNil: [ self visitSuperSend: anIRSend ]", messageSends: ["ifNil:ifNotNil:", "visitSend:", "visitSuperSend:", "classSend"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRSequence:", category: 'visiting', fn: function (anIRSequence){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutSequenceWith_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(anIRSequence)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(self._stream())._nextPutStatementWith_(self._visit_(each)); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRSequence:",{anIRSequence:anIRSequence},smalltalk.IRJSTranslator)})}, args: ["anIRSequence"], source: "visitIRSequence: anIRSequence\x0a\x09self stream nextPutSequenceWith: [\x0a\x09\x09anIRSequence instructions do: [ :each |\x0a\x09\x09\x09self stream nextPutStatementWith: (self visit: each) ]]", messageSends: ["nextPutSequenceWith:", "do:", "nextPutStatementWith:", "visit:", "stream", "instructions"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRTempDeclaration:", category: 'visiting', fn: function (anIRTempDeclaration){ var self=this; return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"visitIRTempDeclaration:",{anIRTempDeclaration:anIRTempDeclaration},smalltalk.IRJSTranslator)})}, args: ["anIRTempDeclaration"], source: "visitIRTempDeclaration: anIRTempDeclaration\x0a\x09\x22self stream\x0a\x09\x09nextPutAll: 'var ', anIRTempDeclaration name asVariableName, ';';\x0a\x09\x09lf\x22", messageSends: [], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRValue:", category: 'visiting', fn: function (anIRValue){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutAll_(_st(_st(anIRValue)._value())._asJavascript()); return self}, function($ctx1) {$ctx1.fill(self,"visitIRValue:",{anIRValue:anIRValue},smalltalk.IRJSTranslator)})}, args: ["anIRValue"], source: "visitIRValue: anIRValue\x0a\x09self stream nextPutAll: anIRValue value asJavascript", messageSends: ["nextPutAll:", "asJavascript", "value", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRVariable:", category: 'visiting', fn: function (anIRVariable){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(anIRVariable)._variable())._name()).__eq("thisContext"); if(smalltalk.assert($1)){ _st(self._stream())._nextPutAll_("smalltalk.getThisContext()"); } else { _st(self._stream())._nextPutAll_(_st(_st(anIRVariable)._variable())._alias()); }; return self}, function($ctx1) {$ctx1.fill(self,"visitIRVariable:",{anIRVariable:anIRVariable},smalltalk.IRJSTranslator)})}, args: ["anIRVariable"], source: "visitIRVariable: anIRVariable\x0a\x09anIRVariable variable name = 'thisContext'\x0a\x09\x09ifTrue: [ self stream nextPutAll: 'smalltalk.getThisContext()' ]\x0a\x09\x09ifFalse: [ self stream nextPutAll: anIRVariable variable alias ]", messageSends: ["ifTrue:ifFalse:", "nextPutAll:", "stream", "alias", "variable", "=", "name"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRVerbatim:", category: 'visiting', fn: function (anIRVerbatim){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutStatementWith_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutAll_(_st(anIRVerbatim)._source()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRVerbatim:",{anIRVerbatim:anIRVerbatim},smalltalk.IRJSTranslator)})}, args: ["anIRVerbatim"], source: "visitIRVerbatim: anIRVerbatim\x0a\x09self stream nextPutStatementWith: [\x0a\x09\x09self stream nextPutAll: anIRVerbatim source ]", messageSends: ["nextPutStatementWith:", "nextPutAll:", "source", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitReceiver:", category: 'visiting', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(anIRInstruction)._needsBoxingAsReceiver(); if(! smalltalk.assert($1)){ $2=self._visit_(anIRInstruction); return $2; }; _st(self._stream())._nextPutAll_("_st("); self._visit_(anIRInstruction); _st(self._stream())._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"visitReceiver:",{anIRInstruction:anIRInstruction},smalltalk.IRJSTranslator)})}, args: ["anIRInstruction"], source: "visitReceiver: anIRInstruction\x0a\x09anIRInstruction needsBoxingAsReceiver ifFalse: [ ^ self visit: anIRInstruction ].\x0a\x09\x0a\x09self stream nextPutAll: '_st('.\x0a\x09self visit: anIRInstruction.\x0a\x09self stream nextPutAll: ')'", messageSends: ["ifFalse:", "visit:", "needsBoxingAsReceiver", "nextPutAll:", "stream"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitSend:", category: 'visiting', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { self._visitReceiver_(_st(_st(anIRSend)._instructions())._first()); _st(self._stream())._nextPutAll_(_st(".".__comma(_st(_st(anIRSend)._selector())._asSelector())).__comma("(")); _st(_st(_st(anIRSend)._instructions())._allButFirst())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self._stream())._nextPutAll_(")"); return self}, function($ctx1) {$ctx1.fill(self,"visitSend:",{anIRSend:anIRSend},smalltalk.IRJSTranslator)})}, args: ["anIRSend"], source: "visitSend: anIRSend\x0a\x09self visitReceiver: anIRSend instructions first.\x0a\x09self stream nextPutAll: '.', anIRSend selector asSelector, '('.\x0a\x09anIRSend instructions allButFirst\x0a\x09\x09do: [ :each | self visit: each ]\x0a\x09\x09separatedBy: [ self stream nextPutAll: ',' ].\x0a\x09self stream nextPutAll: ')'", messageSends: ["visitReceiver:", "first", "instructions", "nextPutAll:", ",", "asSelector", "selector", "stream", "do:separatedBy:", "visit:", "allButFirst"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitSuperSend:", category: 'visiting', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self._stream(); _st($1)._nextPutAll_(_st(self._currentClass())._asJavascript()); _st($1)._nextPutAll_(".superclass.fn.prototype."); _st($1)._nextPutAll_(_st(_st(_st(anIRSend)._selector())._asSelector()).__comma(".apply(")); $2=_st($1)._nextPutAll_("_st("); self._visit_(_st(_st(anIRSend)._instructions())._first()); _st(self._stream())._nextPutAll_("), ["); _st(_st(_st(anIRSend)._instructions())._allButFirst())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self._stream())._nextPutAll_("])"); return self}, function($ctx1) {$ctx1.fill(self,"visitSuperSend:",{anIRSend:anIRSend},smalltalk.IRJSTranslator)})}, args: ["anIRSend"], source: "visitSuperSend: anIRSend\x0a\x09self stream\x0a\x09\x09nextPutAll: self currentClass asJavascript;\x0a\x09\x09nextPutAll: '.superclass.fn.prototype.';\x0a\x09\x09nextPutAll: anIRSend selector asSelector, '.apply(';\x0a\x09\x09nextPutAll: '_st('.\x0a\x09self visit: anIRSend instructions first.\x0a\x09self stream nextPutAll: '), ['.\x0a\x09anIRSend instructions allButFirst\x0a\x09\x09do: [ :each | self visit: each ]\x0a\x09\x09separatedBy: [ self stream nextPutAll: ',' ].\x0a\x09self stream nextPutAll: '])'", messageSends: ["nextPutAll:", "asJavascript", "currentClass", "stream", ",", "asSelector", "selector", "visit:", "first", "instructions", "do:separatedBy:", "allButFirst"], referencedClasses: [] }), smalltalk.IRJSTranslator); smalltalk.addClass('JSStream', smalltalk.Object, ['stream'], 'Compiler-IR'); smalltalk.addMethod( smalltalk.method({ selector: "contents", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@stream"])._contents(); return $1; }, function($ctx1) {$ctx1.fill(self,"contents",{},smalltalk.JSStream)})}, args: [], source: "contents\x0a\x09^ stream contents", messageSends: ["contents"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.JSStream.superclass.fn.prototype._initialize.apply(_st(self), []); self["@stream"]=""._writeStream(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.JSStream)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09stream := '' writeStream.", messageSends: ["initialize", "writeStream"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "lf", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._lf(); return self}, function($ctx1) {$ctx1.fill(self,"lf",{},smalltalk.JSStream)})}, args: [], source: "lf\x0a\x09stream lf", messageSends: ["lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPut:", category: 'streaming', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._nextPut_(aString); return self}, function($ctx1) {$ctx1.fill(self,"nextPut:",{aString:aString},smalltalk.JSStream)})}, args: ["aString"], source: "nextPut: aString\x0a\x09stream nextPut: aString", messageSends: ["nextPut:"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutAll:", category: 'streaming', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._nextPutAll_(aString); return self}, function($ctx1) {$ctx1.fill(self,"nextPutAll:",{aString:aString},smalltalk.JSStream)})}, args: ["aString"], source: "nextPutAll: aString\x0a\x09stream nextPutAll: aString", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutAssignment", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._nextPutAll_("="); return self}, function($ctx1) {$ctx1.fill(self,"nextPutAssignment",{},smalltalk.JSStream)})}, args: [], source: "nextPutAssignment\x0a\x09stream nextPutAll: '='", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutBlockContextFor:during:", category: 'streaming', fn: function (anIRClosure,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7,$8; $1=self; _st($1)._nextPutAll_(_st("return smalltalk.withContext(function(".__comma(_st(_st(anIRClosure)._scope())._alias())).__comma(") {")); $2=_st($1)._lf(); _st(aBlock)._value(); $3=self; _st($3)._nextPutAll_(_st("}, function(".__comma(_st(_st(anIRClosure)._scope())._alias())).__comma(") {")); $4=_st($3)._nextPutAll_(_st(_st(_st(anIRClosure)._scope())._alias()).__comma(".fillBlock({")); _st(_st(anIRClosure)._locals())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { $5=self; _st($5)._nextPutAll_(_st(each)._asVariableName()); _st($5)._nextPutAll_(":"); $6=_st($5)._nextPutAll_(_st(each)._asVariableName()); return $6; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $7=self; _st($7)._nextPutAll_("},"); $8=_st($7)._nextPutAll_(_st(_st(_st(_st(anIRClosure)._scope())._outerScope())._alias()).__comma(")})")); return self}, function($ctx1) {$ctx1.fill(self,"nextPutBlockContextFor:during:",{anIRClosure:anIRClosure,aBlock:aBlock},smalltalk.JSStream)})}, args: ["anIRClosure", "aBlock"], source: "nextPutBlockContextFor: anIRClosure during: aBlock\x0a\x09self\x0a\x09\x09nextPutAll: 'return smalltalk.withContext(function(', anIRClosure scope alias, ') {'; lf.\x0a\x09\x0a\x09aBlock value.\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '}, function(', anIRClosure scope alias, ') {';\x0a\x09\x09nextPutAll: anIRClosure scope alias, '.fillBlock({'.\x0a\x09\x0a\x09anIRClosure locals\x0a\x09\x09do: [ :each |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09nextPutAll: each asVariableName;\x0a\x09\x09\x09\x09nextPutAll: ':';\x0a\x09\x09\x09\x09nextPutAll: each asVariableName]\x0a\x09\x09separatedBy: [ self nextPutAll: ',' ].\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '},';\x0a\x09\x09nextPutAll: anIRClosure scope outerScope alias, ')})'", messageSends: ["nextPutAll:", ",", "alias", "scope", "lf", "value", "do:separatedBy:", "asVariableName", "locals", "outerScope"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutClassRefFunction:", category: 'streaming', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self["@stream"]; _st($1)._nextPutAll_("function $"); _st($1)._nextPutAll_(aString); _st($1)._nextPutAll_("(){return smalltalk."); _st($1)._nextPutAll_(aString); _st($1)._nextPutAll_("||(typeof "); _st($1)._nextPutAll_(aString); _st($1)._nextPutAll_("==\x22undefined\x22?nil:"); _st($1)._nextPutAll_(aString); _st($1)._nextPutAll_(")}"); $2=_st($1)._lf(); return self}, function($ctx1) {$ctx1.fill(self,"nextPutClassRefFunction:",{aString:aString},smalltalk.JSStream)})}, args: ["aString"], source: "nextPutClassRefFunction: aString\x0a\x09\x22Creates an inner function $aString into method and called as `$Foo()`whenever the global is accessed.\x0a\x09This ensures that undefined global access will answer `nil`\x22\x0a\x09\x0a\x09stream\x0a\x09\x09nextPutAll: 'function $';\x0a\x09\x09nextPutAll: aString;\x0a\x09\x09nextPutAll: '(){return smalltalk.';\x0a\x09\x09nextPutAll: aString;\x0a\x09\x09nextPutAll: '||(typeof ';\x0a\x09\x09nextPutAll: aString;\x0a\x09\x09nextPutAll: '==\x22undefined\x22?nil:';\x0a\x09\x09nextPutAll: aString;\x0a\x09\x09nextPutAll: ')}';\x0a\x09\x09lf", messageSends: ["nextPutAll:", "lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutClosureWith:arguments:", category: 'streaming', fn: function (aBlock,anArray){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; _st(self["@stream"])._nextPutAll_("(function("); _st(anArray)._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(_st(each)._asVariableName()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPut_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=self["@stream"]; _st($1)._nextPutAll_("){"); $2=_st($1)._lf(); _st(aBlock)._value(); _st(self["@stream"])._nextPutAll_("})"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutClosureWith:arguments:",{aBlock:aBlock,anArray:anArray},smalltalk.JSStream)})}, args: ["aBlock", "anArray"], source: "nextPutClosureWith: aBlock arguments: anArray\x0a\x09stream nextPutAll: '(function('.\x0a\x09anArray\x0a\x09\x09do: [ :each | stream nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ stream nextPut: ',' ].\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '})'", messageSends: ["nextPutAll:", "do:separatedBy:", "asVariableName", "nextPut:", "lf", "value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutContextFor:during:", category: 'streaming', fn: function (aMethod,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7,$8; $1=self; _st($1)._nextPutAll_(_st("return smalltalk.withContext(function(".__comma(_st(_st(aMethod)._scope())._alias())).__comma(") { ")); $2=_st($1)._lf(); _st(aBlock)._value(); $3=self; _st($3)._nextPutAll_(_st(_st("}, function(".__comma(_st(_st(aMethod)._scope())._alias())).__comma(") {")).__comma(_st(_st(aMethod)._scope())._alias())); $4=_st($3)._nextPutAll_(_st(".fill(self,".__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(",{")); _st(_st(aMethod)._locals())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { $5=self; _st($5)._nextPutAll_(_st(each)._asVariableName()); _st($5)._nextPutAll_(":"); $6=_st($5)._nextPutAll_(_st(each)._asVariableName()); return $6; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $7=self; _st($7)._nextPutAll_("},"); _st($7)._nextPutAll_(_st(_st(aMethod)._theClass())._asJavascript()); $8=_st($7)._nextPutAll_(")})"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutContextFor:during:",{aMethod:aMethod,aBlock:aBlock},smalltalk.JSStream)})}, args: ["aMethod", "aBlock"], source: "nextPutContextFor: aMethod during: aBlock\x0a\x09self\x0a\x09\x09nextPutAll: 'return smalltalk.withContext(function(', aMethod scope alias, ') { '; lf.\x0a\x09aBlock value.\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '}, function(', aMethod scope alias, ') {', aMethod scope alias;\x0a\x09\x09nextPutAll: '.fill(self,', aMethod selector asJavascript, ',{'.\x0a\x0a\x09aMethod locals\x0a\x09\x09do: [ :each |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09nextPutAll: each asVariableName;\x0a\x09\x09\x09\x09nextPutAll: ':';\x0a\x09\x09\x09\x09nextPutAll: each asVariableName]\x0a\x09\x09separatedBy: [ self nextPutAll: ',' ].\x0a\x09\x0a\x09self\x0a\x09\x09nextPutAll: '},';\x0a\x09\x09nextPutAll: aMethod theClass asJavascript;\x0a\x09\x09nextPutAll: ')})'", messageSends: ["nextPutAll:", ",", "alias", "scope", "lf", "value", "asJavascript", "selector", "do:separatedBy:", "asVariableName", "locals", "theClass"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutFunctionWith:arguments:", category: 'streaming', fn: function (aBlock,anArray){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; _st(self["@stream"])._nextPutAll_("fn: function("); _st(anArray)._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(_st(each)._asVariableName()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPut_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=self["@stream"]; _st($1)._nextPutAll_("){"); $2=_st($1)._lf(); $3=self["@stream"]; _st($3)._nextPutAll_("var self=this;"); $4=_st($3)._lf(); _st(aBlock)._value(); _st(self["@stream"])._nextPutAll_("}"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutFunctionWith:arguments:",{aBlock:aBlock,anArray:anArray},smalltalk.JSStream)})}, args: ["aBlock", "anArray"], source: "nextPutFunctionWith: aBlock arguments: anArray\x0a\x09stream nextPutAll: 'fn: function('.\x0a\x09anArray\x0a\x09\x09do: [ :each | stream nextPutAll: each asVariableName ]\x0a\x09\x09separatedBy: [ stream nextPut: ',' ].\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09stream nextPutAll: 'var self=this;'; lf.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '}'", messageSends: ["nextPutAll:", "do:separatedBy:", "asVariableName", "nextPut:", "lf", "value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutIf:with:", category: 'streaming', fn: function (aBlock,anotherBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; _st(self["@stream"])._nextPutAll_("if("); _st(aBlock)._value(); $1=self["@stream"]; _st($1)._nextPutAll_("){"); $2=_st($1)._lf(); _st(anotherBlock)._value(); _st(self["@stream"])._nextPutAll_("}"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutIf:with:",{aBlock:aBlock,anotherBlock:anotherBlock},smalltalk.JSStream)})}, args: ["aBlock", "anotherBlock"], source: "nextPutIf: aBlock with: anotherBlock\x0a\x09stream nextPutAll: 'if('.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09anotherBlock value.\x0a\x09stream nextPutAll: '}'", messageSends: ["nextPutAll:", "value", "lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutIfElse:with:with:", category: 'streaming', fn: function (aBlock,ifBlock,elseBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; _st(self["@stream"])._nextPutAll_("if("); _st(aBlock)._value(); $1=self["@stream"]; _st($1)._nextPutAll_("){"); $2=_st($1)._lf(); _st(ifBlock)._value(); $3=self["@stream"]; _st($3)._nextPutAll_("} else {"); $4=_st($3)._lf(); _st(elseBlock)._value(); _st(self["@stream"])._nextPutAll_("}"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutIfElse:with:with:",{aBlock:aBlock,ifBlock:ifBlock,elseBlock:elseBlock},smalltalk.JSStream)})}, args: ["aBlock", "ifBlock", "elseBlock"], source: "nextPutIfElse: aBlock with: ifBlock with: elseBlock\x0a\x09stream nextPutAll: 'if('.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: '){'; lf.\x0a\x09ifBlock value.\x0a\x09stream nextPutAll: '} else {'; lf.\x0a\x09elseBlock value.\x0a\x09stream nextPutAll: '}'", messageSends: ["nextPutAll:", "value", "lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutMethodDeclaration:with:", category: 'streaming', fn: function (aMethod,aBlock){ var self=this; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6; $1=self["@stream"]; _st($1)._nextPutAll_("smalltalk.method({"); _st($1)._lf(); _st($1)._nextPutAll_(_st("selector: ".__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(",")); _st($1)._lf(); _st($1)._nextPutAll_(_st("source: ".__comma(_st(_st(aMethod)._source())._asJavascript())).__comma(",")); $2=_st($1)._lf(); _st(aBlock)._value(); $3=self["@stream"]; _st($3)._nextPutAll_(_st(",".__comma(_st($String())._lf())).__comma("messageSends: ")); _st($3)._nextPutAll_(_st(_st(_st(_st(aMethod)._messageSends())._asArray())._asJavascript()).__comma(",")); _st($3)._lf(); _st($3)._nextPutAll_(_st("args: ".__comma(_st(_st(_st(_st(aMethod)._arguments())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._value(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})))._asArray())._asJavascript())).__comma(",")); _st($3)._lf(); $4=_st($3)._nextPutAll_("referencedClasses: ["); _st(_st(aMethod)._classReferences())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(_st(each)._asJavascript()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $5=self["@stream"]; _st($5)._nextPutAll_("]"); $6=_st($5)._nextPutAll_("})"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutMethodDeclaration:with:",{aMethod:aMethod,aBlock:aBlock},smalltalk.JSStream)})}, args: ["aMethod", "aBlock"], source: "nextPutMethodDeclaration: aMethod with: aBlock\x0a\x09stream\x0a\x09\x09nextPutAll: 'smalltalk.method({'; lf;\x0a\x09\x09nextPutAll: 'selector: ', aMethod selector asJavascript, ','; lf;\x0a\x09\x09nextPutAll: 'source: ', aMethod source asJavascript, ',';lf.\x0a\x09aBlock value.\x0a\x09stream\x0a\x09\x09nextPutAll: ',', String lf, 'messageSends: ';\x0a\x09\x09nextPutAll: aMethod messageSends asArray asJavascript, ','; lf;\x0a\x09\x09nextPutAll: 'args: ', (aMethod arguments collect: [ :each | each value ]) asArray asJavascript, ','; lf;\x0a\x09\x09nextPutAll: 'referencedClasses: ['.\x0a\x09aMethod classReferences\x0a\x09\x09do: [:each | stream nextPutAll: each asJavascript]\x0a\x09\x09separatedBy: [stream nextPutAll: ','].\x0a\x09stream\x0a\x09\x09nextPutAll: ']';\x0a\x09\x09nextPutAll: '})'", messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "selector", "source", "value", "asArray", "messageSends", "collect:", "arguments", "do:separatedBy:", "classReferences"], referencedClasses: ["String"] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutNonLocalReturnHandlingWith:", category: 'streaming', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=self["@stream"]; _st($1)._nextPutAll_("var $early={};"); _st($1)._lf(); _st($1)._nextPutAll_("try {"); $2=_st($1)._lf(); _st(aBlock)._value(); $3=self["@stream"]; _st($3)._nextPutAll_("}"); _st($3)._lf(); _st($3)._nextPutAll_("catch(e) {if(e===$early)return e[0]; throw e}"); $4=_st($3)._lf(); return self}, function($ctx1) {$ctx1.fill(self,"nextPutNonLocalReturnHandlingWith:",{aBlock:aBlock},smalltalk.JSStream)})}, args: ["aBlock"], source: "nextPutNonLocalReturnHandlingWith: aBlock\x0a\x09stream\x0a\x09\x09nextPutAll: 'var $early={};'; lf;\x0a\x09\x09nextPutAll: 'try {'; lf.\x0a\x09aBlock value.\x0a\x09stream\x0a\x09\x09nextPutAll: '}'; lf;\x0a\x09\x09nextPutAll: 'catch(e) {if(e===$early)return e[0]; throw e}'; lf", messageSends: ["nextPutAll:", "lf", "value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutNonLocalReturnWith:", category: 'streaming', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._nextPutAll_("throw $early=["); _st(aBlock)._value(); _st(self["@stream"])._nextPutAll_("]"); return self}, function($ctx1) {$ctx1.fill(self,"nextPutNonLocalReturnWith:",{aBlock:aBlock},smalltalk.JSStream)})}, args: ["aBlock"], source: "nextPutNonLocalReturnWith: aBlock\x0a\x09stream nextPutAll: 'throw $early=['.\x0a\x09aBlock value.\x0a\x09stream nextPutAll: ']'", messageSends: ["nextPutAll:", "value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutReturn", category: 'streaming', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@stream"])._nextPutAll_("return "); return self}, function($ctx1) {$ctx1.fill(self,"nextPutReturn",{},smalltalk.JSStream)})}, args: [], source: "nextPutReturn\x0a\x09stream nextPutAll: 'return '", messageSends: ["nextPutAll:"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutReturnWith:", category: 'streaming', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._nextPutReturn(); _st(aBlock)._value(); return self}, function($ctx1) {$ctx1.fill(self,"nextPutReturnWith:",{aBlock:aBlock},smalltalk.JSStream)})}, args: ["aBlock"], source: "nextPutReturnWith: aBlock\x0a\x09self nextPutReturn.\x0a\x09aBlock value", messageSends: ["nextPutReturn", "value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutSequenceWith:", category: 'streaming', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aBlock)._value(); return self}, function($ctx1) {$ctx1.fill(self,"nextPutSequenceWith:",{aBlock:aBlock},smalltalk.JSStream)})}, args: ["aBlock"], source: "nextPutSequenceWith: aBlock\x0a\x09\x22stream\x0a\x09\x09nextPutAll: 'switch(smalltalk.thisContext.pc){'; lf.\x22\x0a\x09aBlock value.\x0a\x09\x22stream\x0a\x09\x09nextPutAll: '};'; lf\x22", messageSends: ["value"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutStatementWith:", category: 'streaming', fn: function (aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; _st(aBlock)._value(); $1=self["@stream"]; _st($1)._nextPutAll_(";"); $2=_st($1)._lf(); return self}, function($ctx1) {$ctx1.fill(self,"nextPutStatementWith:",{aBlock:aBlock},smalltalk.JSStream)})}, args: ["aBlock"], source: "nextPutStatementWith: aBlock\x0a\x09aBlock value.\x0a\x09stream nextPutAll: ';'; lf", messageSends: ["value", "nextPutAll:", "lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "nextPutVars:", category: 'streaming', fn: function (aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; var $early={}; try { _st(aCollection)._ifEmpty_((function(){ return smalltalk.withContext(function($ctx2) { $1=self; throw $early=[$1]; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self["@stream"])._nextPutAll_("var "); _st(aCollection)._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@stream"])._nextPutAll_(","); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $2=self["@stream"]; _st($2)._nextPutAll_(";"); $3=_st($2)._lf(); return self} catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"nextPutVars:",{aCollection:aCollection},smalltalk.JSStream)})}, args: ["aCollection"], source: "nextPutVars: aCollection\x0a\x09aCollection ifEmpty: [ ^self ].\x0a\x09\x0a\x09stream nextPutAll: 'var '.\x0a\x09aCollection\x0a\x09\x09do: [ :each | stream nextPutAll: each ]\x0a\x09\x09separatedBy: [ stream nextPutAll: ',' ].\x0a\x09stream nextPutAll: ';'; lf", messageSends: ["ifEmpty:", "nextPutAll:", "do:separatedBy:", "lf"], referencedClasses: [] }), smalltalk.JSStream); smalltalk.addMethod( smalltalk.method({ selector: "appendToInstruction:", category: '*Compiler-IR', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { _st(anIRInstruction)._appendBlock_(self); return self}, function($ctx1) {$ctx1.fill(self,"appendToInstruction:",{anIRInstruction:anIRInstruction},smalltalk.BlockClosure)})}, args: ["anIRInstruction"], source: "appendToInstruction: anIRInstruction\x0a\x09anIRInstruction appendBlock: self", messageSends: ["appendBlock:"], referencedClasses: [] }), smalltalk.BlockClosure); smalltalk.addMethod( smalltalk.method({ selector: "asVariableName", category: '*Compiler-IR', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st(_st($Smalltalk())._current())._reservedWords())._includes_(self); if(smalltalk.assert($2)){ $1=self.__comma("_"); } else { $1=self; }; return $1; }, function($ctx1) {$ctx1.fill(self,"asVariableName",{},smalltalk.String)})}, args: [], source: "asVariableName\x0a\x09^ (Smalltalk current reservedWords includes: self)\x0a\x09\x09ifTrue: [ self, '_' ]\x0a\x09\x09ifFalse: [ self ]", messageSends: ["ifTrue:ifFalse:", ",", "includes:", "reservedWords", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.String); }); define("amber_core/Compiler-Inlining", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Compiler-IR", "amber_core/Kernel-Objects", "amber_core/Compiler-Core"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-Inlining'); smalltalk.packages["Compiler-Inlining"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('IRInlinedAssignment', smalltalk.IRAssignment, [], 'Compiler-Inlining'); smalltalk.IRInlinedAssignment.comment="I represent an inlined assignment instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRInlinedAssignment_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedAssignment)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRInlinedAssignment: self", messageSends: ["visitIRInlinedAssignment:"], referencedClasses: [] }), smalltalk.IRInlinedAssignment); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInlinedAssignment)})}, args: [], source: "isInlined\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInlinedAssignment); smalltalk.addClass('IRInlinedClosure', smalltalk.IRClosure, [], 'Compiler-Inlining'); smalltalk.IRInlinedClosure.comment="I represent an inlined closure instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedClosure_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedClosure)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedClosure: self", messageSends: ["visitIRInlinedClosure:"], referencedClasses: [] }), smalltalk.IRInlinedClosure); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInlinedClosure)})}, args: [], source: "isInlined\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInlinedClosure); smalltalk.addClass('IRInlinedReturn', smalltalk.IRReturn, [], 'Compiler-Inlining'); smalltalk.IRInlinedReturn.comment="I represent an inlined local return instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aVisitor)._visitIRInlinedReturn_(self); return $1; }, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedReturn)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09^ aVisitor visitIRInlinedReturn: self", messageSends: ["visitIRInlinedReturn:"], referencedClasses: [] }), smalltalk.IRInlinedReturn); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInlinedReturn)})}, args: [], source: "isInlined\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInlinedReturn); smalltalk.addClass('IRInlinedSend', smalltalk.IRSend, [], 'Compiler-Inlining'); smalltalk.IRInlinedSend.comment="I am the abstract super class of inlined message send instructions."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitInlinedSend_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedSend)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitInlinedSend: self", messageSends: ["visitInlinedSend:"], referencedClasses: [] }), smalltalk.IRInlinedSend); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInlinedSend)})}, args: [], source: "isInlined\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInlinedSend); smalltalk.addClass('IRInlinedIfFalse', smalltalk.IRInlinedSend, [], 'Compiler-Inlining'); smalltalk.IRInlinedIfFalse.comment="I represent an inlined `#ifFalse:` message send instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedIfFalse_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedIfFalse)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedIfFalse: self", messageSends: ["visitIRInlinedIfFalse:"], referencedClasses: [] }), smalltalk.IRInlinedIfFalse); smalltalk.addClass('IRInlinedIfNilIfNotNil', smalltalk.IRInlinedSend, [], 'Compiler-Inlining'); smalltalk.IRInlinedIfNilIfNotNil.comment="I represent an inlined `#ifNil:ifNotNil:` message send instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedIfNilIfNotNil_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedIfNilIfNotNil)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedIfNilIfNotNil: self", messageSends: ["visitIRInlinedIfNilIfNotNil:"], referencedClasses: [] }), smalltalk.IRInlinedIfNilIfNotNil); smalltalk.addClass('IRInlinedIfTrue', smalltalk.IRInlinedSend, [], 'Compiler-Inlining'); smalltalk.IRInlinedIfTrue.comment="I represent an inlined `#ifTrue:` message send instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedIfTrue_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedIfTrue)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedIfTrue: self", messageSends: ["visitIRInlinedIfTrue:"], referencedClasses: [] }), smalltalk.IRInlinedIfTrue); smalltalk.addClass('IRInlinedIfTrueIfFalse', smalltalk.IRInlinedSend, [], 'Compiler-Inlining'); smalltalk.IRInlinedIfTrueIfFalse.comment="I represent an inlined `#ifTrue:ifFalse:` message send instruction."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedIfTrueIfFalse_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedIfTrueIfFalse)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedIfTrueIfFalse: self", messageSends: ["visitIRInlinedIfTrueIfFalse:"], referencedClasses: [] }), smalltalk.IRInlinedIfTrueIfFalse); smalltalk.addClass('IRInlinedSequence', smalltalk.IRBlockSequence, [], 'Compiler-Inlining'); smalltalk.IRInlinedSequence.comment="I represent a (block) sequence inside an inlined closure instruction (instance of `IRInlinedClosure`)."; smalltalk.addMethod( smalltalk.method({ selector: "accept:", category: 'visiting', fn: function (aVisitor){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aVisitor)._visitIRInlinedSequence_(self); return self}, function($ctx1) {$ctx1.fill(self,"accept:",{aVisitor:aVisitor},smalltalk.IRInlinedSequence)})}, args: ["aVisitor"], source: "accept: aVisitor\x0a\x09aVisitor visitIRInlinedSequence: self", messageSends: ["visitIRInlinedSequence:"], referencedClasses: [] }), smalltalk.IRInlinedSequence); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.IRInlinedSequence)})}, args: [], source: "isInlined\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.IRInlinedSequence); smalltalk.addClass('IRInliner', smalltalk.IRVisitor, [], 'Compiler-Inlining'); smalltalk.IRInliner.comment="I visit an IR tree, inlining message sends and block closures.\x0a\x0aMessage selectors that can be inlined are answered by `IRSendInliner >> #inlinedSelectors`"; smalltalk.addMethod( smalltalk.method({ selector: "assignmentInliner", category: 'factory', fn: function (){ var self=this; function $IRAssignmentInliner(){return smalltalk.IRAssignmentInliner||(typeof IRAssignmentInliner=="undefined"?nil:IRAssignmentInliner)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRAssignmentInliner())._new(); _st($2)._translator_(self); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"assignmentInliner",{},smalltalk.IRInliner)})}, args: [], source: "assignmentInliner\x0a\x09^ IRAssignmentInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself", messageSends: ["translator:", "new", "yourself"], referencedClasses: ["IRAssignmentInliner"] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "returnInliner", category: 'factory', fn: function (){ var self=this; function $IRReturnInliner(){return smalltalk.IRReturnInliner||(typeof IRReturnInliner=="undefined"?nil:IRReturnInliner)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRReturnInliner())._new(); _st($2)._translator_(self); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"returnInliner",{},smalltalk.IRInliner)})}, args: [], source: "returnInliner\x0a\x09^ IRReturnInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself", messageSends: ["translator:", "new", "yourself"], referencedClasses: ["IRReturnInliner"] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "sendInliner", category: 'factory', fn: function (){ var self=this; function $IRSendInliner(){return smalltalk.IRSendInliner||(typeof IRSendInliner=="undefined"?nil:IRSendInliner)} return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st($IRSendInliner())._new(); _st($2)._translator_(self); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"sendInliner",{},smalltalk.IRInliner)})}, args: [], source: "sendInliner\x0a\x09^ IRSendInliner new\x0a\x09\x09translator: self;\x0a\x09\x09yourself", messageSends: ["translator:", "new", "yourself"], referencedClasses: ["IRSendInliner"] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "shouldInlineAssignment:", category: 'testing', fn: function (anIRAssignment){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(anIRAssignment)._isInlined())._not())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(_st(anIRAssignment)._instructions())._last())._isSend())._and_((function(){ return smalltalk.withContext(function($ctx3) { return self._shouldInlineSend_(_st(_st(anIRAssignment)._instructions())._last()); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"shouldInlineAssignment:",{anIRAssignment:anIRAssignment},smalltalk.IRInliner)})}, args: ["anIRAssignment"], source: "shouldInlineAssignment: anIRAssignment\x0a\x09^ anIRAssignment isInlined not and: [\x0a\x09\x09anIRAssignment instructions last isSend and: [\x0a\x09\x09\x09self shouldInlineSend: (anIRAssignment instructions last) ]]", messageSends: ["and:", "shouldInlineSend:", "last", "instructions", "isSend", "not", "isInlined"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "shouldInlineReturn:", category: 'testing', fn: function (anIRReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(anIRReturn)._isInlined())._not())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(_st(anIRReturn)._instructions())._first())._isSend())._and_((function(){ return smalltalk.withContext(function($ctx3) { return self._shouldInlineSend_(_st(_st(anIRReturn)._instructions())._first()); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"shouldInlineReturn:",{anIRReturn:anIRReturn},smalltalk.IRInliner)})}, args: ["anIRReturn"], source: "shouldInlineReturn: anIRReturn\x0a\x09^ anIRReturn isInlined not and: [\x0a\x09\x09anIRReturn instructions first isSend and: [\x0a\x09\x09\x09self shouldInlineSend: (anIRReturn instructions first) ]]", messageSends: ["and:", "shouldInlineSend:", "first", "instructions", "isSend", "not", "isInlined"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "shouldInlineSend:", category: 'testing', fn: function (anIRSend){ var self=this; function $IRSendInliner(){return smalltalk.IRSendInliner||(typeof IRSendInliner=="undefined"?nil:IRSendInliner)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(anIRSend)._isInlined())._not())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st($IRSendInliner())._shouldInline_(anIRSend); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"shouldInlineSend:",{anIRSend:anIRSend},smalltalk.IRInliner)})}, args: ["anIRSend"], source: "shouldInlineSend: anIRSend\x0a\x09^ anIRSend isInlined not and: [\x0a\x09\x09IRSendInliner shouldInline: anIRSend ]", messageSends: ["and:", "shouldInline:", "not", "isInlined"], referencedClasses: ["IRSendInliner"] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "transformNonLocalReturn:", category: 'visiting', fn: function (anIRNonLocalReturn){ var self=this; var localReturn; function $IRReturn(){return smalltalk.IRReturn||(typeof IRReturn=="undefined"?nil:IRReturn)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; $1=_st(_st(anIRNonLocalReturn)._scope())._canInlineNonLocalReturns(); if(smalltalk.assert($1)){ _st(_st(_st(anIRNonLocalReturn)._scope())._methodScope())._removeNonLocalReturn_(_st(anIRNonLocalReturn)._scope()); $2=_st($IRReturn())._new(); _st($2)._scope_(_st(anIRNonLocalReturn)._scope()); $3=_st($2)._yourself(); localReturn=$3; localReturn; _st(_st(anIRNonLocalReturn)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(localReturn)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(anIRNonLocalReturn)._replaceWith_(localReturn); $4=localReturn; return $4; }; $5=smalltalk.IRInliner.superclass.fn.prototype._visitIRNonLocalReturn_.apply(_st(self), [anIRNonLocalReturn]); return $5; }, function($ctx1) {$ctx1.fill(self,"transformNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn,localReturn:localReturn},smalltalk.IRInliner)})}, args: ["anIRNonLocalReturn"], source: "transformNonLocalReturn: anIRNonLocalReturn\x0a\x09\x22Replace a non local return into a local return\x22\x0a\x0a\x09| localReturn |\x0a\x09anIRNonLocalReturn scope canInlineNonLocalReturns ifTrue: [\x0a\x09\x09anIRNonLocalReturn scope methodScope removeNonLocalReturn: anIRNonLocalReturn scope.\x0a\x09\x09localReturn := IRReturn new\x0a\x09\x09\x09scope: anIRNonLocalReturn scope;\x0a\x09\x09\x09yourself.\x0a\x09\x09anIRNonLocalReturn instructions do: [ :each |\x0a\x09\x09\x09localReturn add: each ].\x0a\x09\x09anIRNonLocalReturn replaceWith: localReturn.\x0a\x09\x09^ localReturn ].\x0a\x09^ super visitIRNonLocalReturn: anIRNonLocalReturn", messageSends: ["ifTrue:", "removeNonLocalReturn:", "scope", "methodScope", "scope:", "new", "yourself", "do:", "add:", "instructions", "replaceWith:", "canInlineNonLocalReturns", "visitIRNonLocalReturn:"], referencedClasses: ["IRReturn"] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "visitIRAssignment:", category: 'visiting', fn: function (anIRAssignment){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._shouldInlineAssignment_(anIRAssignment); if(smalltalk.assert($2)){ $1=_st(self._assignmentInliner())._inlineAssignment_(anIRAssignment); } else { $1=smalltalk.IRInliner.superclass.fn.prototype._visitIRAssignment_.apply(_st(self), [anIRAssignment]); }; return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRAssignment:",{anIRAssignment:anIRAssignment},smalltalk.IRInliner)})}, args: ["anIRAssignment"], source: "visitIRAssignment: anIRAssignment\x0a\x09^ (self shouldInlineAssignment: anIRAssignment)\x0a\x09\x09ifTrue: [ self assignmentInliner inlineAssignment: anIRAssignment ]\x0a\x09\x09ifFalse: [ super visitIRAssignment: anIRAssignment ]", messageSends: ["ifTrue:ifFalse:", "inlineAssignment:", "assignmentInliner", "visitIRAssignment:", "shouldInlineAssignment:"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "visitIRNonLocalReturn:", category: 'visiting', fn: function (anIRNonLocalReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._transformNonLocalReturn_(anIRNonLocalReturn); return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRNonLocalReturn:",{anIRNonLocalReturn:anIRNonLocalReturn},smalltalk.IRInliner)})}, args: ["anIRNonLocalReturn"], source: "visitIRNonLocalReturn: anIRNonLocalReturn\x0a\x09^ self transformNonLocalReturn: anIRNonLocalReturn", messageSends: ["transformNonLocalReturn:"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "visitIRReturn:", category: 'visiting', fn: function (anIRReturn){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._shouldInlineReturn_(anIRReturn); if(smalltalk.assert($2)){ $1=_st(self._returnInliner())._inlineReturn_(anIRReturn); } else { $1=smalltalk.IRInliner.superclass.fn.prototype._visitIRReturn_.apply(_st(self), [anIRReturn]); }; return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRReturn:",{anIRReturn:anIRReturn},smalltalk.IRInliner)})}, args: ["anIRReturn"], source: "visitIRReturn: anIRReturn\x0a\x09^ (self shouldInlineReturn: anIRReturn)\x0a\x09\x09ifTrue: [ self returnInliner inlineReturn: anIRReturn ]\x0a\x09\x09ifFalse: [ super visitIRReturn: anIRReturn ]", messageSends: ["ifTrue:ifFalse:", "inlineReturn:", "returnInliner", "visitIRReturn:", "shouldInlineReturn:"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addMethod( smalltalk.method({ selector: "visitIRSend:", category: 'visiting', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._shouldInlineSend_(anIRSend); if(smalltalk.assert($2)){ $1=_st(self._sendInliner())._inlineSend_(anIRSend); } else { $1=smalltalk.IRInliner.superclass.fn.prototype._visitIRSend_.apply(_st(self), [anIRSend]); }; return $1; }, function($ctx1) {$ctx1.fill(self,"visitIRSend:",{anIRSend:anIRSend},smalltalk.IRInliner)})}, args: ["anIRSend"], source: "visitIRSend: anIRSend\x0a\x09^ (self shouldInlineSend: anIRSend)\x0a\x09\x09ifTrue: [ self sendInliner inlineSend: anIRSend ]\x0a\x09\x09ifFalse: [ super visitIRSend: anIRSend ]", messageSends: ["ifTrue:ifFalse:", "inlineSend:", "sendInliner", "visitIRSend:", "shouldInlineSend:"], referencedClasses: [] }), smalltalk.IRInliner); smalltalk.addClass('IRInliningJSTranslator', smalltalk.IRJSTranslator, [], 'Compiler-Inlining'); smalltalk.IRInliningJSTranslator.comment="I am a specialized JavaScript translator able to write inlined IR instructions to JavaScript stream (`JSStream` instance)."; smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedAssignment:", category: 'visiting', fn: function (anIRInlinedAssignment){ var self=this; return smalltalk.withContext(function($ctx1) { self._visit_(_st(_st(anIRInlinedAssignment)._instructions())._last()); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedAssignment:",{anIRInlinedAssignment:anIRInlinedAssignment},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedAssignment"], source: "visitIRInlinedAssignment: anIRInlinedAssignment\x0a\x09self visit: anIRInlinedAssignment instructions last", messageSends: ["visit:", "last", "instructions"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedClosure:", category: 'visiting', fn: function (anIRInlinedClosure){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutVars_(_st(_st(anIRInlinedClosure)._tempDeclarations())._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._name())._asVariableName(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}))); _st(_st(anIRInlinedClosure)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return self._visit_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedClosure:",{anIRInlinedClosure:anIRInlinedClosure},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedClosure"], source: "visitIRInlinedClosure: anIRInlinedClosure\x0a\x09self stream nextPutVars: (anIRInlinedClosure tempDeclarations collect: [ :each |\x0a\x09\x09each name asVariableName ]).\x0a\x09anIRInlinedClosure instructions do: [ :each |\x0a\x09\x09self visit: each ]", messageSends: ["nextPutVars:", "collect:", "asVariableName", "name", "tempDeclarations", "stream", "do:", "visit:", "instructions"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedIfFalse:", category: 'visiting', fn: function (anIRInlinedIfFalse){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutIf_with_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutAll_("! smalltalk.assert("); self._visit_(_st(_st(anIRInlinedIfFalse)._instructions())._first()); return _st(self._stream())._nextPutAll_(")"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfFalse)._instructions())._last()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfFalse:",{anIRInlinedIfFalse:anIRInlinedIfFalse},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedIfFalse"], source: "visitIRInlinedIfFalse: anIRInlinedIfFalse\x0a\x09self stream nextPutIf: [\x0a\x09\x09self stream nextPutAll: '! smalltalk.assert('.\x0a\x09\x09self visit: anIRInlinedIfFalse instructions first.\x0a\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09with: [ self visit: anIRInlinedIfFalse instructions last ]", messageSends: ["nextPutIf:with:", "nextPutAll:", "stream", "visit:", "first", "instructions", "last"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedIfNil:", category: 'visiting', fn: function (anIRInlinedIfNil){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutIf_with_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutAll_("($receiver = "); self._visit_(_st(_st(anIRInlinedIfNil)._instructions())._first()); return _st(self._stream())._nextPutAll_(") == nil || $receiver == undefined"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfNil)._instructions())._last()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfNil:",{anIRInlinedIfNil:anIRInlinedIfNil},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedIfNil"], source: "visitIRInlinedIfNil: anIRInlinedIfNil\x0a\x09self stream nextPutIf: [\x0a\x09\x09self stream nextPutAll: '($receiver = '.\x0a\x09\x09self visit: anIRInlinedIfNil instructions first.\x0a\x09\x09self stream nextPutAll: ') == nil || $receiver == undefined' ]\x0a\x09\x09with: [ self visit: anIRInlinedIfNil instructions last ]", messageSends: ["nextPutIf:with:", "nextPutAll:", "stream", "visit:", "first", "instructions", "last"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedIfNilIfNotNil:", category: 'visiting', fn: function (anIRInlinedIfNilIfNotNil){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutIfElse_with_with_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutAll_("($receiver = "); self._visit_(_st(_st(anIRInlinedIfNilIfNotNil)._instructions())._first()); return _st(self._stream())._nextPutAll_(") == nil || $receiver == undefined"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfNilIfNotNil)._instructions())._second()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfNilIfNotNil)._instructions())._third()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfNilIfNotNil:",{anIRInlinedIfNilIfNotNil:anIRInlinedIfNilIfNotNil},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedIfNilIfNotNil"], source: "visitIRInlinedIfNilIfNotNil: anIRInlinedIfNilIfNotNil\x0a\x09self stream\x0a\x09\x09nextPutIfElse: [\x0a\x09\x09\x09self stream nextPutAll: '($receiver = '.\x0a\x09\x09\x09self visit: anIRInlinedIfNilIfNotNil instructions first.\x0a\x09\x09\x09self stream nextPutAll: ') == nil || $receiver == undefined' ]\x0a\x09\x09with: [ self visit: anIRInlinedIfNilIfNotNil instructions second ]\x0a\x09\x09with: [ self visit: anIRInlinedIfNilIfNotNil instructions third ]", messageSends: ["nextPutIfElse:with:with:", "nextPutAll:", "stream", "visit:", "first", "instructions", "second", "third"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedIfTrue:", category: 'visiting', fn: function (anIRInlinedIfTrue){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutIf_with_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutAll_("smalltalk.assert("); self._visit_(_st(_st(anIRInlinedIfTrue)._instructions())._first()); return _st(self._stream())._nextPutAll_(")"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfTrue)._instructions())._last()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfTrue:",{anIRInlinedIfTrue:anIRInlinedIfTrue},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedIfTrue"], source: "visitIRInlinedIfTrue: anIRInlinedIfTrue\x0a\x09self stream nextPutIf: [\x0a\x09\x09self stream nextPutAll: 'smalltalk.assert('.\x0a\x09\x09self visit: anIRInlinedIfTrue instructions first.\x0a\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09with: [ self visit: anIRInlinedIfTrue instructions last ]", messageSends: ["nextPutIf:with:", "nextPutAll:", "stream", "visit:", "first", "instructions", "last"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedIfTrueIfFalse:", category: 'visiting', fn: function (anIRInlinedIfTrueIfFalse){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutIfElse_with_with_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._stream())._nextPutAll_("smalltalk.assert("); self._visit_(_st(_st(anIRInlinedIfTrueIfFalse)._instructions())._first()); return _st(self._stream())._nextPutAll_(")"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfTrueIfFalse)._instructions())._second()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedIfTrueIfFalse)._instructions())._third()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedIfTrueIfFalse:",{anIRInlinedIfTrueIfFalse:anIRInlinedIfTrueIfFalse},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedIfTrueIfFalse"], source: "visitIRInlinedIfTrueIfFalse: anIRInlinedIfTrueIfFalse\x0a\x09self stream\x0a\x09\x09nextPutIfElse: [\x0a\x09\x09\x09self stream nextPutAll: 'smalltalk.assert('.\x0a\x09\x09\x09self visit: anIRInlinedIfTrueIfFalse instructions first.\x0a\x09\x09\x09self stream nextPutAll: ')' ]\x0a\x09\x09with: [ self visit: anIRInlinedIfTrueIfFalse instructions second ]\x0a\x09\x09with: [ self visit: anIRInlinedIfTrueIfFalse instructions third ]", messageSends: ["nextPutIfElse:with:with:", "nextPutAll:", "stream", "visit:", "first", "instructions", "second", "third"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedNonLocalReturn:", category: 'visiting', fn: function (anIRInlinedReturn){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._stream())._nextPutStatementWith_((function(){ return smalltalk.withContext(function($ctx2) { return self._visit_(_st(_st(anIRInlinedReturn)._instructions())._last()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(self._stream())._nextPutNonLocalReturnWith_((function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedNonLocalReturn:",{anIRInlinedReturn:anIRInlinedReturn},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedReturn"], source: "visitIRInlinedNonLocalReturn: anIRInlinedReturn\x0a\x09self stream nextPutStatementWith: [\x0a\x09\x09self visit: anIRInlinedReturn instructions last ].\x0a\x09self stream nextPutNonLocalReturnWith: [ ]", messageSends: ["nextPutStatementWith:", "visit:", "last", "instructions", "stream", "nextPutNonLocalReturnWith:"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedReturn:", category: 'visiting', fn: function (anIRInlinedReturn){ var self=this; return smalltalk.withContext(function($ctx1) { self._visit_(_st(_st(anIRInlinedReturn)._instructions())._last()); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedReturn:",{anIRInlinedReturn:anIRInlinedReturn},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedReturn"], source: "visitIRInlinedReturn: anIRInlinedReturn\x0a\x09self visit: anIRInlinedReturn instructions last", messageSends: ["visit:", "last", "instructions"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addMethod( smalltalk.method({ selector: "visitIRInlinedSequence:", category: 'visiting', fn: function (anIRInlinedSequence){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(anIRInlinedSequence)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self._stream())._nextPutStatementWith_((function(){ return smalltalk.withContext(function($ctx3) { return self._visit_(each); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"visitIRInlinedSequence:",{anIRInlinedSequence:anIRInlinedSequence},smalltalk.IRInliningJSTranslator)})}, args: ["anIRInlinedSequence"], source: "visitIRInlinedSequence: anIRInlinedSequence\x0a\x09anIRInlinedSequence instructions do: [ :each |\x0a\x09\x09self stream nextPutStatementWith: [ self visit: each ]]", messageSends: ["do:", "nextPutStatementWith:", "visit:", "stream", "instructions"], referencedClasses: [] }), smalltalk.IRInliningJSTranslator); smalltalk.addClass('IRSendInliner', smalltalk.Object, ['send', 'translator'], 'Compiler-Inlining'); smalltalk.IRSendInliner.comment="I inline some message sends and block closure arguments. I heavily rely on #perform: to dispatch inlining methods."; smalltalk.addMethod( smalltalk.method({ selector: "ifFalse:", category: 'inlining', fn: function (anIRInstruction){ var self=this; function $IRInlinedIfFalse(){return smalltalk.IRInlinedIfFalse||(typeof IRInlinedIfFalse=="undefined"?nil:IRInlinedIfFalse)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._inlinedSend_with_(_st($IRInlinedIfFalse())._new(),anIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifFalse:",{anIRInstruction:anIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction"], source: "ifFalse: anIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfFalse new with: anIRInstruction", messageSends: ["inlinedSend:with:", "new"], referencedClasses: ["IRInlinedIfFalse"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifFalse:ifTrue:", category: 'inlining', fn: function (anIRInstruction,anotherIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._perform_withArguments_("ifTrue:ifFalse:",[anotherIRInstruction,anIRInstruction]); return $1; }, function($ctx1) {$ctx1.fill(self,"ifFalse:ifTrue:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction", "anotherIRInstruction"], source: "ifFalse: anIRInstruction ifTrue: anotherIRInstruction\x0a\x09^ self perform: #ifTrue:ifFalse: withArguments: { anotherIRInstruction. anIRInstruction }", messageSends: ["perform:withArguments:"], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:", category: 'inlining', fn: function (anIRInstruction){ var self=this; function $IRInlinedIfNilIfNotNil(){return smalltalk.IRInlinedIfNilIfNotNil||(typeof IRInlinedIfNilIfNotNil=="undefined"?nil:IRInlinedIfNilIfNotNil)} function $IRClosure(){return smalltalk.IRClosure||(typeof IRClosure=="undefined"?nil:IRClosure)} function $IRBlockSequence(){return smalltalk.IRBlockSequence||(typeof IRBlockSequence=="undefined"?nil:IRBlockSequence)} return smalltalk.withContext(function($ctx1) { var $2,$3,$4,$5,$1; $2=_st($IRClosure())._new(); _st($2)._scope_(_st(_st(anIRInstruction)._scope())._copy()); $3=_st($IRBlockSequence())._new(); _st($3)._add_(_st(_st(self._send())._instructions())._first()); $4=_st($3)._yourself(); _st($2)._add_($4); $5=_st($2)._yourself(); $1=self._inlinedSend_with_with_(_st($IRInlinedIfNilIfNotNil())._new(),anIRInstruction,$5); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:",{anIRInstruction:anIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction"], source: "ifNil: anIRInstruction\x0a\x09^ self\x0a\x09\x09inlinedSend: IRInlinedIfNilIfNotNil new\x0a\x09\x09with: anIRInstruction\x0a\x09\x09with: (IRClosure new\x0a\x09\x09\x09scope: anIRInstruction scope copy;\x0a\x09\x09\x09add: (IRBlockSequence new\x0a\x09\x09\x09\x09add: self send instructions first;\x0a\x09\x09\x09\x09yourself);\x0a\x09\x09\x09yourself)", messageSends: ["inlinedSend:with:with:", "new", "scope:", "copy", "scope", "add:", "first", "instructions", "send", "yourself"], referencedClasses: ["IRInlinedIfNilIfNotNil", "IRClosure", "IRBlockSequence"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifNil:ifNotNil:", category: 'inlining', fn: function (anIRInstruction,anotherIRInstruction){ var self=this; function $IRInlinedIfNilIfNotNil(){return smalltalk.IRInlinedIfNilIfNotNil||(typeof IRInlinedIfNilIfNotNil=="undefined"?nil:IRInlinedIfNilIfNotNil)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._inlinedSend_with_with_(_st($IRInlinedIfNilIfNotNil())._new(),anIRInstruction,anotherIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNil:ifNotNil:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction", "anotherIRInstruction"], source: "ifNil: anIRInstruction ifNotNil: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfNilIfNotNil new with: anIRInstruction with: anotherIRInstruction", messageSends: ["inlinedSend:with:with:", "new"], referencedClasses: ["IRInlinedIfNilIfNotNil"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:", category: 'inlining', fn: function (anIRInstruction){ var self=this; function $IRInlinedIfNilIfNotNil(){return smalltalk.IRInlinedIfNilIfNotNil||(typeof IRInlinedIfNilIfNotNil=="undefined"?nil:IRInlinedIfNilIfNotNil)} function $IRClosure(){return smalltalk.IRClosure||(typeof IRClosure=="undefined"?nil:IRClosure)} function $IRBlockSequence(){return smalltalk.IRBlockSequence||(typeof IRBlockSequence=="undefined"?nil:IRBlockSequence)} return smalltalk.withContext(function($ctx1) { var $2,$3,$4,$5,$1; $2=_st($IRClosure())._new(); _st($2)._scope_(_st(_st(anIRInstruction)._scope())._copy()); $3=_st($IRBlockSequence())._new(); _st($3)._add_(_st(_st(self._send())._instructions())._first()); $4=_st($3)._yourself(); _st($2)._add_($4); $5=_st($2)._yourself(); $1=self._inlinedSend_with_with_(_st($IRInlinedIfNilIfNotNil())._new(),$5,anIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:",{anIRInstruction:anIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction"], source: "ifNotNil: anIRInstruction\x0a\x09^ self\x0a\x09\x09inlinedSend: IRInlinedIfNilIfNotNil new\x0a\x09\x09with: (IRClosure new\x0a\x09\x09\x09scope: anIRInstruction scope copy;\x0a\x09\x09\x09add: (IRBlockSequence new\x0a\x09\x09\x09\x09add: self send instructions first;\x0a\x09\x09\x09\x09yourself);\x0a\x09\x09\x09yourself)\x0a\x09\x09with: anIRInstruction", messageSends: ["inlinedSend:with:with:", "new", "scope:", "copy", "scope", "add:", "first", "instructions", "send", "yourself"], referencedClasses: ["IRInlinedIfNilIfNotNil", "IRClosure", "IRBlockSequence"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifNotNil:ifNil:", category: 'inlining', fn: function (anIRInstruction,anotherIRInstruction){ var self=this; function $IRInlinedIfNilIfNotNil(){return smalltalk.IRInlinedIfNilIfNotNil||(typeof IRInlinedIfNilIfNotNil=="undefined"?nil:IRInlinedIfNilIfNotNil)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._inlinedSend_with_with_(_st($IRInlinedIfNilIfNotNil())._new(),anotherIRInstruction,anIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifNotNil:ifNil:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction", "anotherIRInstruction"], source: "ifNotNil: anIRInstruction ifNil: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfNilIfNotNil new with: anotherIRInstruction with: anIRInstruction", messageSends: ["inlinedSend:with:with:", "new"], referencedClasses: ["IRInlinedIfNilIfNotNil"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifTrue:", category: 'inlining', fn: function (anIRInstruction){ var self=this; function $IRInlinedIfTrue(){return smalltalk.IRInlinedIfTrue||(typeof IRInlinedIfTrue=="undefined"?nil:IRInlinedIfTrue)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._inlinedSend_with_(_st($IRInlinedIfTrue())._new(),anIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifTrue:",{anIRInstruction:anIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction"], source: "ifTrue: anIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfTrue new with: anIRInstruction", messageSends: ["inlinedSend:with:", "new"], referencedClasses: ["IRInlinedIfTrue"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "ifTrue:ifFalse:", category: 'inlining', fn: function (anIRInstruction,anotherIRInstruction){ var self=this; function $IRInlinedIfTrueIfFalse(){return smalltalk.IRInlinedIfTrueIfFalse||(typeof IRInlinedIfTrueIfFalse=="undefined"?nil:IRInlinedIfTrueIfFalse)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._inlinedSend_with_with_(_st($IRInlinedIfTrueIfFalse())._new(),anIRInstruction,anotherIRInstruction); return $1; }, function($ctx1) {$ctx1.fill(self,"ifTrue:ifFalse:",{anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction},smalltalk.IRSendInliner)})}, args: ["anIRInstruction", "anotherIRInstruction"], source: "ifTrue: anIRInstruction ifFalse: anotherIRInstruction\x0a\x09^ self inlinedSend: IRInlinedIfTrueIfFalse new with: anIRInstruction with: anotherIRInstruction", messageSends: ["inlinedSend:with:with:", "new"], referencedClasses: ["IRInlinedIfTrueIfFalse"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlineClosure:", category: 'inlining', fn: function (anIRClosure){ var self=this; var inlinedClosure,sequence,statements; function $IRTempDeclaration(){return smalltalk.IRTempDeclaration||(typeof IRTempDeclaration=="undefined"?nil:IRTempDeclaration)} function $AliasVar(){return smalltalk.AliasVar||(typeof AliasVar=="undefined"?nil:AliasVar)} function $IRVariable(){return smalltalk.IRVariable||(typeof IRVariable=="undefined"?nil:IRVariable)} function $IRAssignment(){return smalltalk.IRAssignment||(typeof IRAssignment=="undefined"?nil:IRAssignment)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6,$7,$8,$9,$10; inlinedClosure=self._inlinedClosure(); _st(inlinedClosure)._scope_(_st(anIRClosure)._scope()); _st(_st(anIRClosure)._tempDeclarations())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(inlinedClosure)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); sequence=self._inlinedSequence(); _st(_st(anIRClosure)._arguments())._do_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st($IRTempDeclaration())._new(); _st($1)._name_(each); $2=_st($1)._yourself(); _st(inlinedClosure)._add_($2); $3=_st($IRAssignment())._new(); $4=_st($AliasVar())._new(); _st($4)._scope_(_st(inlinedClosure)._scope()); _st($4)._name_(each); $5=_st($4)._yourself(); _st($3)._add_(_st(_st($IRVariable())._new())._variable_($5)); $6=_st($AliasVar())._new(); _st($6)._scope_(_st(inlinedClosure)._scope()); _st($6)._name_("$receiver"); $7=_st($6)._yourself(); _st($3)._add_(_st(_st($IRVariable())._new())._variable_($7)); $8=_st($3)._yourself(); return _st(sequence)._add_($8); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(inlinedClosure)._add_(sequence); statements=_st(_st(_st(anIRClosure)._instructions())._last())._instructions(); _st(statements)._ifNotEmpty_((function(){ return smalltalk.withContext(function($ctx2) { _st(_st(statements)._allButLast())._do_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(sequence)._add_(each); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})})); $9=_st(_st(_st(statements)._last())._isReturn())._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(_st(statements)._last())._isBlockReturn(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); if(smalltalk.assert($9)){ return _st(sequence)._add_(_st(_st(_st(statements)._last())._instructions())._first()); } else { return _st(sequence)._add_(_st(statements)._last()); }; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $10=inlinedClosure; return $10; }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,inlinedClosure:inlinedClosure,sequence:sequence,statements:statements},smalltalk.IRSendInliner)})}, args: ["anIRClosure"], source: "inlineClosure: anIRClosure\x0a\x09| inlinedClosure sequence statements |\x0a\x0a\x09inlinedClosure := self inlinedClosure.\x0a\x09inlinedClosure scope: anIRClosure scope.\x0a\x0a\x09\x22Add the possible temp declarations\x22\x0a\x09anIRClosure tempDeclarations do: [ :each |\x0a\x09\x09\x09inlinedClosure add: each ].\x0a\x0a\x09\x22Add a block sequence\x22\x0a\x09sequence := self inlinedSequence.\x0a\x0a\x09\x22Map the closure arguments to the receiver of the message send\x22\x0a\x09anIRClosure arguments do: [ :each |\x0a\x09\x09inlinedClosure add: (IRTempDeclaration new name: each; yourself).\x0a\x09\x09sequence add: (IRAssignment new\x0a\x09\x09\x09add: (IRVariable new variable: (AliasVar new scope: inlinedClosure scope; name: each; yourself));\x0a\x09\x09\x09add: (IRVariable new variable: (AliasVar new scope: inlinedClosure scope; name: '$receiver'; yourself));\x0a\x09\x09\x09yourself) ].\x0a\x09\x09\x09\x0a\x09\x22To ensure the correct order of the closure instructions: first the temps then the sequence\x22\x0a\x09inlinedClosure add: sequence.\x0a\x0a\x09\x22Get all the statements\x22\x0a\x09statements := anIRClosure instructions last instructions.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09statements allButLast do: [ :each | sequence add: each ].\x0a\x0a\x09\x09\x22Inlined closures don't have implicit local returns\x22\x0a\x09\x09(statements last isReturn and: [ statements last isBlockReturn ])\x0a\x09\x09\x09ifTrue: [ sequence add: statements last instructions first ]\x0a\x09\x09\x09ifFalse: [ sequence add: statements last ] ].\x0a\x0a\x09^ inlinedClosure", messageSends: ["inlinedClosure", "scope:", "scope", "do:", "add:", "tempDeclarations", "inlinedSequence", "name:", "new", "yourself", "variable:", "arguments", "instructions", "last", "ifNotEmpty:", "allButLast", "ifTrue:ifFalse:", "first", "and:", "isBlockReturn", "isReturn"], referencedClasses: ["IRTempDeclaration", "AliasVar", "IRVariable", "IRAssignment"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlineSend:", category: 'inlining', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; self._send_(anIRSend); $1=self._perform_withArguments_(_st(self._send())._selector(),_st(_st(self._send())._instructions())._allButFirst()); return $1; }, function($ctx1) {$ctx1.fill(self,"inlineSend:",{anIRSend:anIRSend},smalltalk.IRSendInliner)})}, args: ["anIRSend"], source: "inlineSend: anIRSend\x0a\x09self send: anIRSend.\x0a\x09^ self\x0a\x09\x09perform: self send selector\x0a\x09\x09withArguments: self send instructions allButFirst", messageSends: ["send:", "perform:withArguments:", "selector", "send", "allButFirst", "instructions"], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedClosure", category: 'factory', fn: function (){ var self=this; function $IRInlinedClosure(){return smalltalk.IRInlinedClosure||(typeof IRInlinedClosure=="undefined"?nil:IRInlinedClosure)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRInlinedClosure())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"inlinedClosure",{},smalltalk.IRSendInliner)})}, args: [], source: "inlinedClosure\x0a\x09^ IRInlinedClosure new", messageSends: ["new"], referencedClasses: ["IRInlinedClosure"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedSend:with:", category: 'inlining', fn: function (inlinedSend,anIRInstruction){ var self=this; var inlinedClosure; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; $1=_st(anIRInstruction)._isClosure(); if(! smalltalk.assert($1)){ self._inliningError_("Message argument should be a block"); }; $2=_st(_st(_st(anIRInstruction)._arguments())._size()).__eq((0)); if(! smalltalk.assert($2)){ self._inliningError_("Inlined block should have zero argument"); }; inlinedClosure=_st(self._translator())._visit_(self._inlineClosure_(anIRInstruction)); $3=inlinedSend; _st($3)._add_(_st(_st(self._send())._instructions())._first()); $4=_st($3)._add_(inlinedClosure); _st(self._send())._replaceWith_(inlinedSend); $5=inlinedSend; return $5; }, function($ctx1) {$ctx1.fill(self,"inlinedSend:with:",{inlinedSend:inlinedSend,anIRInstruction:anIRInstruction,inlinedClosure:inlinedClosure},smalltalk.IRSendInliner)})}, args: ["inlinedSend", "anIRInstruction"], source: "inlinedSend: inlinedSend with: anIRInstruction\x0a\x09| inlinedClosure |\x0a\x0a\x09anIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x09anIRInstruction arguments size = 0 ifFalse: [ self inliningError: 'Inlined block should have zero argument' ].\x0a\x0a\x09inlinedClosure := self translator visit: (self inlineClosure: anIRInstruction).\x0a\x0a\x09inlinedSend\x0a\x09\x09add: self send instructions first;\x0a\x09\x09add: inlinedClosure.\x0a\x0a\x09self send replaceWith: inlinedSend.\x0a\x0a\x09^ inlinedSend", messageSends: ["ifFalse:", "inliningError:", "isClosure", "=", "size", "arguments", "visit:", "inlineClosure:", "translator", "add:", "first", "instructions", "send", "replaceWith:"], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedSend:with:with:", category: 'inlining', fn: function (inlinedSend,anIRInstruction,anotherIRInstruction){ var self=this; var inlinedClosure1,inlinedClosure2; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; $1=_st(anIRInstruction)._isClosure(); if(! smalltalk.assert($1)){ self._inliningError_("Message argument should be a block"); }; $2=_st(anotherIRInstruction)._isClosure(); if(! smalltalk.assert($2)){ self._inliningError_("Message argument should be a block"); }; inlinedClosure1=_st(self._translator())._visit_(self._inlineClosure_(anIRInstruction)); inlinedClosure2=_st(self._translator())._visit_(self._inlineClosure_(anotherIRInstruction)); $3=inlinedSend; _st($3)._add_(_st(_st(self._send())._instructions())._first()); _st($3)._add_(inlinedClosure1); $4=_st($3)._add_(inlinedClosure2); _st(self._send())._replaceWith_(inlinedSend); $5=inlinedSend; return $5; }, function($ctx1) {$ctx1.fill(self,"inlinedSend:with:with:",{inlinedSend:inlinedSend,anIRInstruction:anIRInstruction,anotherIRInstruction:anotherIRInstruction,inlinedClosure1:inlinedClosure1,inlinedClosure2:inlinedClosure2},smalltalk.IRSendInliner)})}, args: ["inlinedSend", "anIRInstruction", "anotherIRInstruction"], source: "inlinedSend: inlinedSend with: anIRInstruction with: anotherIRInstruction\x0a\x09| inlinedClosure1 inlinedClosure2 |\x0a\x0a\x09anIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x09anotherIRInstruction isClosure ifFalse: [ self inliningError: 'Message argument should be a block' ].\x0a\x0a\x09inlinedClosure1 := self translator visit: (self inlineClosure: anIRInstruction).\x0a\x09inlinedClosure2 := self translator visit: (self inlineClosure: anotherIRInstruction).\x0a\x0a\x09inlinedSend\x0a\x09\x09add: self send instructions first;\x0a\x09\x09add: inlinedClosure1;\x0a\x09\x09add: inlinedClosure2.\x0a\x0a\x09self send replaceWith: inlinedSend.\x0a\x09^ inlinedSend", messageSends: ["ifFalse:", "inliningError:", "isClosure", "visit:", "inlineClosure:", "translator", "add:", "first", "instructions", "send", "replaceWith:"], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedSequence", category: 'factory', fn: function (){ var self=this; function $IRInlinedSequence(){return smalltalk.IRInlinedSequence||(typeof IRInlinedSequence=="undefined"?nil:IRInlinedSequence)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRInlinedSequence())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"inlinedSequence",{},smalltalk.IRSendInliner)})}, args: [], source: "inlinedSequence\x0a\x09^ IRInlinedSequence new", messageSends: ["new"], referencedClasses: ["IRInlinedSequence"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inliningError:", category: 'error handling', fn: function (aString){ var self=this; function $InliningError(){return smalltalk.InliningError||(typeof InliningError=="undefined"?nil:InliningError)} return smalltalk.withContext(function($ctx1) { _st($InliningError())._signal_(aString); return self}, function($ctx1) {$ctx1.fill(self,"inliningError:",{aString:aString},smalltalk.IRSendInliner)})}, args: ["aString"], source: "inliningError: aString\x0a\x09InliningError signal: aString", messageSends: ["signal:"], referencedClasses: ["InliningError"] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "send", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@send"]; return $1; }, function($ctx1) {$ctx1.fill(self,"send",{},smalltalk.IRSendInliner)})}, args: [], source: "send\x0a\x09^ send", messageSends: [], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "send:", category: 'accessing', fn: function (anIRSend){ var self=this; return smalltalk.withContext(function($ctx1) { self["@send"]=anIRSend; return self}, function($ctx1) {$ctx1.fill(self,"send:",{anIRSend:anIRSend},smalltalk.IRSendInliner)})}, args: ["anIRSend"], source: "send: anIRSend\x0a\x09send := anIRSend", messageSends: [], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "translator", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@translator"]; return $1; }, function($ctx1) {$ctx1.fill(self,"translator",{},smalltalk.IRSendInliner)})}, args: [], source: "translator\x0a\x09^ translator", messageSends: [], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "translator:", category: 'accessing', fn: function (anASTTranslator){ var self=this; return smalltalk.withContext(function($ctx1) { self["@translator"]=anASTTranslator; return self}, function($ctx1) {$ctx1.fill(self,"translator:",{anASTTranslator:anASTTranslator},smalltalk.IRSendInliner)})}, args: ["anASTTranslator"], source: "translator: anASTTranslator\x0a\x09translator := anASTTranslator", messageSends: [], referencedClasses: [] }), smalltalk.IRSendInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedSelectors", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=["ifTrue:", "ifFalse:", "ifTrue:ifFalse:", "ifFalse:ifTrue:", "ifNil:", "ifNotNil:", "ifNil:ifNotNil:", "ifNotNil:ifNil:"]; return $1; }, function($ctx1) {$ctx1.fill(self,"inlinedSelectors",{},smalltalk.IRSendInliner.klass)})}, args: [], source: "inlinedSelectors\x0a\x09^ #('ifTrue:' 'ifFalse:' 'ifTrue:ifFalse:' 'ifFalse:ifTrue:' 'ifNil:' 'ifNotNil:' 'ifNil:ifNotNil:' 'ifNotNil:ifNil:')", messageSends: [], referencedClasses: [] }), smalltalk.IRSendInliner.klass); smalltalk.addMethod( smalltalk.method({ selector: "shouldInline:", category: 'accessing', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { $1=_st(self._inlinedSelectors())._includes_(_st(anIRInstruction)._selector()); if(! smalltalk.assert($1)){ return false; }; _st(_st(_st(anIRInstruction)._instructions())._allButFirst())._do_((function(each){ return smalltalk.withContext(function($ctx2) { $2=_st(each)._isClosure(); if(! smalltalk.assert($2)){ throw $early=[false]; }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return true; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"shouldInline:",{anIRInstruction:anIRInstruction},smalltalk.IRSendInliner.klass)})}, args: ["anIRInstruction"], source: "shouldInline: anIRInstruction\x0a\x09(self inlinedSelectors includes: anIRInstruction selector) ifFalse: [ ^ false ].\x0a\x09anIRInstruction instructions allButFirst do: [ :each |\x0a\x09\x09each isClosure ifFalse: [ ^ false ]].\x0a\x09^ true", messageSends: ["ifFalse:", "includes:", "selector", "inlinedSelectors", "do:", "isClosure", "allButFirst", "instructions"], referencedClasses: [] }), smalltalk.IRSendInliner.klass); smalltalk.addClass('IRAssignmentInliner', smalltalk.IRSendInliner, ['assignment'], 'Compiler-Inlining'); smalltalk.IRAssignmentInliner.comment="I inline message sends together with assignments by moving them around into the inline closure instructions.\x0a\x0a##Example\x0a\x0a\x09foo\x0a\x09\x09| a |\x0a\x09\x09a := true ifTrue: [ 1 ]\x0a\x0aWill produce:\x0a\x0a\x09if(smalltalk.assert(true) {\x0a\x09\x09a = 1;\x0a\x09};"; smalltalk.addMethod( smalltalk.method({ selector: "assignment", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@assignment"]; return $1; }, function($ctx1) {$ctx1.fill(self,"assignment",{},smalltalk.IRAssignmentInliner)})}, args: [], source: "assignment\x0a\x09^ assignment", messageSends: [], referencedClasses: [] }), smalltalk.IRAssignmentInliner); smalltalk.addMethod( smalltalk.method({ selector: "assignment:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@assignment"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"assignment:",{aNode:aNode},smalltalk.IRAssignmentInliner)})}, args: ["aNode"], source: "assignment: aNode\x0a\x09assignment := aNode", messageSends: [], referencedClasses: [] }), smalltalk.IRAssignmentInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlineAssignment:", category: 'inlining', fn: function (anIRAssignment){ var self=this; var inlinedAssignment; function $IRInlinedAssignment(){return smalltalk.IRInlinedAssignment||(typeof IRInlinedAssignment=="undefined"?nil:IRInlinedAssignment)} return smalltalk.withContext(function($ctx1) { var $1; self._assignment_(anIRAssignment); inlinedAssignment=_st($IRInlinedAssignment())._new(); _st(_st(anIRAssignment)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(inlinedAssignment)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(anIRAssignment)._replaceWith_(inlinedAssignment); self._inlineSend_(_st(_st(inlinedAssignment)._instructions())._last()); $1=inlinedAssignment; return $1; }, function($ctx1) {$ctx1.fill(self,"inlineAssignment:",{anIRAssignment:anIRAssignment,inlinedAssignment:inlinedAssignment},smalltalk.IRAssignmentInliner)})}, args: ["anIRAssignment"], source: "inlineAssignment: anIRAssignment\x0a\x09| inlinedAssignment |\x0a\x09self assignment: anIRAssignment.\x0a\x09inlinedAssignment := IRInlinedAssignment new.\x0a\x09anIRAssignment instructions do: [ :each |\x0a\x09\x09inlinedAssignment add: each ].\x0a\x09anIRAssignment replaceWith: inlinedAssignment.\x0a\x09self inlineSend: inlinedAssignment instructions last.\x0a\x09^ inlinedAssignment", messageSends: ["assignment:", "new", "do:", "add:", "instructions", "replaceWith:", "inlineSend:", "last"], referencedClasses: ["IRInlinedAssignment"] }), smalltalk.IRAssignmentInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlineClosure:", category: 'inlining', fn: function (anIRClosure){ var self=this; var inlinedClosure,statements; function $IRAssignment(){return smalltalk.IRAssignment||(typeof IRAssignment=="undefined"?nil:IRAssignment)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; inlinedClosure=smalltalk.IRAssignmentInliner.superclass.fn.prototype._inlineClosure_.apply(_st(self), [anIRClosure]); statements=_st(_st(_st(inlinedClosure)._instructions())._last())._instructions(); _st(statements)._ifNotEmpty_((function(){ return smalltalk.withContext(function($ctx2) { $1=_st(_st(statements)._last())._canBeAssigned(); if(smalltalk.assert($1)){ $2=_st($IRAssignment())._new(); _st($2)._add_(_st(_st(self._assignment())._instructions())._first()); _st($2)._add_(_st(_st(statements)._last())._copy()); $3=_st($2)._yourself(); return _st(_st(statements)._last())._replaceWith_($3); }; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $4=inlinedClosure; return $4; }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,inlinedClosure:inlinedClosure,statements:statements},smalltalk.IRAssignmentInliner)})}, args: ["anIRClosure"], source: "inlineClosure: anIRClosure\x0a\x09| inlinedClosure statements |\x0a\x0a\x09inlinedClosure := super inlineClosure: anIRClosure.\x0a\x09statements := inlinedClosure instructions last instructions.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09statements last canBeAssigned ifTrue: [\x0a\x09\x09\x09statements last replaceWith: (IRAssignment new\x0a\x09\x09\x09\x09add: self assignment instructions first;\x0a\x09\x09\x09\x09add: statements last copy;\x0a\x09\x09\x09\x09yourself) ] ].\x0a\x0a\x09^ inlinedClosure", messageSends: ["inlineClosure:", "instructions", "last", "ifNotEmpty:", "ifTrue:", "replaceWith:", "add:", "first", "assignment", "new", "copy", "yourself", "canBeAssigned"], referencedClasses: ["IRAssignment"] }), smalltalk.IRAssignmentInliner); smalltalk.addClass('IRReturnInliner', smalltalk.IRSendInliner, [], 'Compiler-Inlining'); smalltalk.IRReturnInliner.comment="I inline message sends with inlined closure together with a return instruction."; smalltalk.addMethod( smalltalk.method({ selector: "inlineClosure:", category: 'inlining', fn: function (anIRClosure){ var self=this; var closure,statements; function $IRReturn(){return smalltalk.IRReturn||(typeof IRReturn=="undefined"?nil:IRReturn)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; closure=smalltalk.IRReturnInliner.superclass.fn.prototype._inlineClosure_.apply(_st(self), [anIRClosure]); statements=_st(_st(_st(closure)._instructions())._last())._instructions(); _st(statements)._ifNotEmpty_((function(){ return smalltalk.withContext(function($ctx2) { $1=_st(_st(statements)._last())._isReturn(); if(! smalltalk.assert($1)){ $2=_st($IRReturn())._new(); _st($2)._add_(_st(_st(statements)._last())._copy()); $3=_st($2)._yourself(); return _st(_st(statements)._last())._replaceWith_($3); }; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $4=closure; return $4; }, function($ctx1) {$ctx1.fill(self,"inlineClosure:",{anIRClosure:anIRClosure,closure:closure,statements:statements},smalltalk.IRReturnInliner)})}, args: ["anIRClosure"], source: "inlineClosure: anIRClosure\x0a\x09| closure statements |\x0a\x0a\x09closure := super inlineClosure: anIRClosure.\x0a\x09statements := closure instructions last instructions.\x0a\x09\x0a\x09statements ifNotEmpty: [\x0a\x09\x09statements last isReturn\x0a\x09\x09\x09ifFalse: [ statements last replaceWith: (IRReturn new\x0a\x09\x09\x09\x09add: statements last copy;\x0a\x09\x09\x09\x09yourself)] ].\x0a\x0a\x09^ closure", messageSends: ["inlineClosure:", "instructions", "last", "ifNotEmpty:", "ifFalse:", "replaceWith:", "add:", "copy", "new", "yourself", "isReturn"], referencedClasses: ["IRReturn"] }), smalltalk.IRReturnInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlineReturn:", category: 'inlining', fn: function (anIRReturn){ var self=this; var return_; return smalltalk.withContext(function($ctx1) { var $1; return_=self._inlinedReturn(); _st(_st(anIRReturn)._instructions())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(return_)._add_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(anIRReturn)._replaceWith_(return_); self._inlineSend_(_st(_st(return_)._instructions())._last()); $1=return_; return $1; }, function($ctx1) {$ctx1.fill(self,"inlineReturn:",{anIRReturn:anIRReturn,return_:return_},smalltalk.IRReturnInliner)})}, args: ["anIRReturn"], source: "inlineReturn: anIRReturn\x0a\x09| return |\x0a\x09return := self inlinedReturn.\x0a\x09anIRReturn instructions do: [ :each |\x0a\x09\x09return add: each ].\x0a\x09anIRReturn replaceWith: return.\x0a\x09self inlineSend: return instructions last.\x0a\x09^ return", messageSends: ["inlinedReturn", "do:", "add:", "instructions", "replaceWith:", "inlineSend:", "last"], referencedClasses: [] }), smalltalk.IRReturnInliner); smalltalk.addMethod( smalltalk.method({ selector: "inlinedReturn", category: 'factory', fn: function (){ var self=this; function $IRInlinedReturn(){return smalltalk.IRInlinedReturn||(typeof IRInlinedReturn=="undefined"?nil:IRInlinedReturn)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRInlinedReturn())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"inlinedReturn",{},smalltalk.IRReturnInliner)})}, args: [], source: "inlinedReturn\x0a\x09^ IRInlinedReturn new", messageSends: ["new"], referencedClasses: ["IRInlinedReturn"] }), smalltalk.IRReturnInliner); smalltalk.addClass('InliningCodeGenerator', smalltalk.CodeGenerator, [], 'Compiler-Inlining'); smalltalk.InliningCodeGenerator.comment="I am a specialized code generator that uses inlining to produce more optimized JavaScript output"; smalltalk.addMethod( smalltalk.method({ selector: "compileNode:", category: 'compiling', fn: function (aNode){ var self=this; var ir,stream; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; _st(self._semanticAnalyzer())._visit_(aNode); ir=_st(self._translator())._visit_(aNode); _st(self._inliner())._visit_(ir); $2=self._irTranslator(); _st($2)._currentClass_(self._currentClass()); _st($2)._visit_(ir); $3=_st($2)._contents(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,ir:ir,stream:stream},smalltalk.InliningCodeGenerator)})}, args: ["aNode"], source: "compileNode: aNode\x0a\x09| ir stream |\x0a\x0a\x09self semanticAnalyzer visit: aNode.\x0a\x09ir := self translator visit: aNode.\x0a\x09self inliner visit: ir.\x0a\x0a\x09^ self irTranslator\x0a\x09\x09currentClass: self currentClass;\x0a\x09\x09visit: ir;\x0a\x09\x09contents", messageSends: ["visit:", "semanticAnalyzer", "translator", "inliner", "currentClass:", "currentClass", "irTranslator", "contents"], referencedClasses: [] }), smalltalk.InliningCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "inliner", category: 'compiling', fn: function (){ var self=this; function $IRInliner(){return smalltalk.IRInliner||(typeof IRInliner=="undefined"?nil:IRInliner)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRInliner())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"inliner",{},smalltalk.InliningCodeGenerator)})}, args: [], source: "inliner\x0a\x09^ IRInliner new", messageSends: ["new"], referencedClasses: ["IRInliner"] }), smalltalk.InliningCodeGenerator); smalltalk.addMethod( smalltalk.method({ selector: "irTranslator", category: 'compiling', fn: function (){ var self=this; function $IRInliningJSTranslator(){return smalltalk.IRInliningJSTranslator||(typeof IRInliningJSTranslator=="undefined"?nil:IRInliningJSTranslator)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st($IRInliningJSTranslator())._new(); return $1; }, function($ctx1) {$ctx1.fill(self,"irTranslator",{},smalltalk.InliningCodeGenerator)})}, args: [], source: "irTranslator\x0a\x09^ IRInliningJSTranslator new", messageSends: ["new"], referencedClasses: ["IRInliningJSTranslator"] }), smalltalk.InliningCodeGenerator); }); define("amber_core/Compiler-Semantic", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects", "amber_core/Compiler-Core"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-Semantic'); smalltalk.packages["Compiler-Semantic"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('LexicalScope', smalltalk.Object, ['node', 'instruction', 'temps', 'args', 'outerScope'], 'Compiler-Semantic'); smalltalk.LexicalScope.comment="I represent a lexical scope where variable names are associated with ScopeVars\x0aInstances are used for block scopes. Method scopes are instances of MethodLexicalScope.\x0a\x0aI am attached to a ScopeVar and method/block nodes.\x0aEach context (method/closure) get a fresh scope that inherits from its outer scope."; smalltalk.addMethod( smalltalk.method({ selector: "addArg:", category: 'adding', fn: function (aString){ var self=this; function $ArgVar(){return smalltalk.ArgVar||(typeof ArgVar=="undefined"?nil:ArgVar)} return smalltalk.withContext(function($ctx1) { _st(self._args())._at_put_(aString,_st($ArgVar())._on_(aString)); _st(_st(self._args())._at_(aString))._scope_(self); return self}, function($ctx1) {$ctx1.fill(self,"addArg:",{aString:aString},smalltalk.LexicalScope)})}, args: ["aString"], source: "addArg: aString\x0a\x09self args at: aString put: (ArgVar on: aString).\x0a\x09(self args at: aString) scope: self", messageSends: ["at:put:", "on:", "args", "scope:", "at:"], referencedClasses: ["ArgVar"] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "addTemp:", category: 'adding', fn: function (aString){ var self=this; function $TempVar(){return smalltalk.TempVar||(typeof TempVar=="undefined"?nil:TempVar)} return smalltalk.withContext(function($ctx1) { _st(self._temps())._at_put_(aString,_st($TempVar())._on_(aString)); _st(_st(self._temps())._at_(aString))._scope_(self); return self}, function($ctx1) {$ctx1.fill(self,"addTemp:",{aString:aString},smalltalk.LexicalScope)})}, args: ["aString"], source: "addTemp: aString\x0a\x09self temps at: aString put: (TempVar on: aString).\x0a\x09(self temps at: aString) scope: self", messageSends: ["at:put:", "on:", "temps", "scope:", "at:"], referencedClasses: ["TempVar"] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1="$ctx".__comma(_st(self._scopeLevel())._asString()); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.LexicalScope)})}, args: [], source: "alias\x0a\x09^ '$ctx', self scopeLevel asString", messageSends: [",", "asString", "scopeLevel"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "allVariableNames", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._args())._keys()).__comma(_st(self._temps())._keys()); return $1; }, function($ctx1) {$ctx1.fill(self,"allVariableNames",{},smalltalk.LexicalScope)})}, args: [], source: "allVariableNames\x0a\x09^ self args keys, self temps keys", messageSends: [",", "keys", "temps", "args"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "args", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@args"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@args"]=_st($Dictionary())._new(); $1=self["@args"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"args",{},smalltalk.LexicalScope)})}, args: [], source: "args\x0a\x09^ args ifNil: [ args := Dictionary new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Dictionary"] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "bindingFor:", category: 'accessing', fn: function (aStringOrNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._pseudoVars())._at_ifAbsent_(_st(aStringOrNode)._value(),(function(){ return smalltalk.withContext(function($ctx2) { return _st(self._args())._at_ifAbsent_(_st(aStringOrNode)._value(),(function(){ return smalltalk.withContext(function($ctx3) { return _st(self._temps())._at_ifAbsent_(_st(aStringOrNode)._value(),(function(){ return smalltalk.withContext(function($ctx4) { return nil; }, function($ctx4) {$ctx4.fillBlock({},$ctx3)})})); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"bindingFor:",{aStringOrNode:aStringOrNode},smalltalk.LexicalScope)})}, args: ["aStringOrNode"], source: "bindingFor: aStringOrNode\x0a\x09^ self pseudoVars at: aStringOrNode value ifAbsent: [\x0a\x09\x09self args at: aStringOrNode value ifAbsent: [\x0a\x09\x09\x09self temps at: aStringOrNode value ifAbsent: [ nil ]]]", messageSends: ["at:ifAbsent:", "value", "temps", "args", "pseudoVars"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "canInlineNonLocalReturns", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._isInlined())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._outerScope())._canInlineNonLocalReturns(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"canInlineNonLocalReturns",{},smalltalk.LexicalScope)})}, args: [], source: "canInlineNonLocalReturns\x0a\x09^ self isInlined and: [ self outerScope canInlineNonLocalReturns ]", messageSends: ["and:", "canInlineNonLocalReturns", "outerScope", "isInlined"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "instruction", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@instruction"]; return $1; }, function($ctx1) {$ctx1.fill(self,"instruction",{},smalltalk.LexicalScope)})}, args: [], source: "instruction\x0a\x09^ instruction", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "instruction:", category: 'accessing', fn: function (anIRInstruction){ var self=this; return smalltalk.withContext(function($ctx1) { self["@instruction"]=anIRInstruction; return self}, function($ctx1) {$ctx1.fill(self,"instruction:",{anIRInstruction:anIRInstruction},smalltalk.LexicalScope)})}, args: ["anIRInstruction"], source: "instruction: anIRInstruction\x0a\x09instruction := anIRInstruction", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "isBlockScope", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._isMethodScope())._not(); return $1; }, function($ctx1) {$ctx1.fill(self,"isBlockScope",{},smalltalk.LexicalScope)})}, args: [], source: "isBlockScope\x0a\x09^ self isMethodScope not", messageSends: ["not", "isMethodScope"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "isInlined", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(self._instruction())._notNil())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._instruction())._isInlined(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"isInlined",{},smalltalk.LexicalScope)})}, args: [], source: "isInlined\x0a\x09^ self instruction notNil and: [\x0a\x09\x09self instruction isInlined ]", messageSends: ["and:", "isInlined", "instruction", "notNil"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "isMethodScope", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isMethodScope",{},smalltalk.LexicalScope)})}, args: [], source: "isMethodScope\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "lookupVariable:", category: 'accessing', fn: function (aNode){ var self=this; var lookup; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; lookup=self._bindingFor_(aNode); $1=lookup; if(($receiver = $1) == nil || $receiver == undefined){ $2=self._outerScope(); if(($receiver = $2) == nil || $receiver == undefined){ lookup=$2; } else { lookup=_st(self._outerScope())._lookupVariable_(aNode); }; lookup; } else { $1; }; $3=lookup; return $3; }, function($ctx1) {$ctx1.fill(self,"lookupVariable:",{aNode:aNode,lookup:lookup},smalltalk.LexicalScope)})}, args: ["aNode"], source: "lookupVariable: aNode\x0a\x09| lookup |\x0a\x09lookup := (self bindingFor: aNode).\x0a\x09lookup ifNil: [\x0a\x09\x09lookup := self outerScope ifNotNil: [\x0a\x09\x09\x09(self outerScope lookupVariable: aNode) ]].\x0a\x09^ lookup", messageSends: ["bindingFor:", "ifNil:", "ifNotNil:", "lookupVariable:", "outerScope"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "methodScope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._outerScope(); if(($receiver = $2) == nil || $receiver == undefined){ $1=$2; } else { $1=_st(self._outerScope())._methodScope(); }; return $1; }, function($ctx1) {$ctx1.fill(self,"methodScope",{},smalltalk.LexicalScope)})}, args: [], source: "methodScope\x0a\x09^ self outerScope ifNotNil: [\x0a\x09\x09self outerScope methodScope ]", messageSends: ["ifNotNil:", "methodScope", "outerScope"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "node", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@node"]; return $1; }, function($ctx1) {$ctx1.fill(self,"node",{},smalltalk.LexicalScope)})}, args: [], source: "node\x0a\x09\x22Answer the node in which I am defined\x22\x0a\x09\x0a\x09^ node", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "node:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@node"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"node:",{aNode:aNode},smalltalk.LexicalScope)})}, args: ["aNode"], source: "node: aNode\x0a\x09node := aNode", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "outerScope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@outerScope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"outerScope",{},smalltalk.LexicalScope)})}, args: [], source: "outerScope\x0a\x09^ outerScope", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "outerScope:", category: 'accessing', fn: function (aLexicalScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@outerScope"]=aLexicalScope; return self}, function($ctx1) {$ctx1.fill(self,"outerScope:",{aLexicalScope:aLexicalScope},smalltalk.LexicalScope)})}, args: ["aLexicalScope"], source: "outerScope: aLexicalScope\x0a\x09outerScope := aLexicalScope", messageSends: [], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "pseudoVars", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._methodScope())._pseudoVars(); return $1; }, function($ctx1) {$ctx1.fill(self,"pseudoVars",{},smalltalk.LexicalScope)})}, args: [], source: "pseudoVars\x0a\x09^ self methodScope pseudoVars", messageSends: ["pseudoVars", "methodScope"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "scopeLevel", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=self._outerScope(); if(($receiver = $1) == nil || $receiver == undefined){ return (1); } else { $1; }; $2=self._isInlined(); if(smalltalk.assert($2)){ $3=_st(self._outerScope())._scopeLevel(); return $3; }; $4=_st(_st(self._outerScope())._scopeLevel()).__plus((1)); return $4; }, function($ctx1) {$ctx1.fill(self,"scopeLevel",{},smalltalk.LexicalScope)})}, args: [], source: "scopeLevel\x0a\x09self outerScope ifNil: [ ^ 1 ].\x0a\x09self isInlined ifTrue: [ ^ self outerScope scopeLevel ].\x0a\x09\x0a\x09^ self outerScope scopeLevel + 1", messageSends: ["ifNil:", "outerScope", "ifTrue:", "scopeLevel", "isInlined", "+"], referencedClasses: [] }), smalltalk.LexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "temps", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@temps"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@temps"]=_st($Dictionary())._new(); $1=self["@temps"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"temps",{},smalltalk.LexicalScope)})}, args: [], source: "temps\x0a\x09^ temps ifNil: [ temps := Dictionary new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Dictionary"] }), smalltalk.LexicalScope); smalltalk.addClass('MethodLexicalScope', smalltalk.LexicalScope, ['iVars', 'pseudoVars', 'unknownVariables', 'localReturn', 'nonLocalReturns'], 'Compiler-Semantic'); smalltalk.MethodLexicalScope.comment="I represent a method scope."; smalltalk.addMethod( smalltalk.method({ selector: "addIVar:", category: 'adding', fn: function (aString){ var self=this; function $InstanceVar(){return smalltalk.InstanceVar||(typeof InstanceVar=="undefined"?nil:InstanceVar)} return smalltalk.withContext(function($ctx1) { _st(self._iVars())._at_put_(aString,_st($InstanceVar())._on_(aString)); _st(_st(self._iVars())._at_(aString))._scope_(self); return self}, function($ctx1) {$ctx1.fill(self,"addIVar:",{aString:aString},smalltalk.MethodLexicalScope)})}, args: ["aString"], source: "addIVar: aString\x0a\x09self iVars at: aString put: (InstanceVar on: aString).\x0a\x09(self iVars at: aString) scope: self", messageSends: ["at:put:", "on:", "iVars", "scope:", "at:"], referencedClasses: ["InstanceVar"] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "addNonLocalReturn:", category: 'adding', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._nonLocalReturns())._add_(aScope); return self}, function($ctx1) {$ctx1.fill(self,"addNonLocalReturn:",{aScope:aScope},smalltalk.MethodLexicalScope)})}, args: ["aScope"], source: "addNonLocalReturn: aScope\x0a\x09self nonLocalReturns add: aScope", messageSends: ["add:", "nonLocalReturns"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "allVariableNames", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(smalltalk.MethodLexicalScope.superclass.fn.prototype._allVariableNames.apply(_st(self), [])).__comma(_st(self._iVars())._keys()); return $1; }, function($ctx1) {$ctx1.fill(self,"allVariableNames",{},smalltalk.MethodLexicalScope)})}, args: [], source: "allVariableNames\x0a\x09^ super allVariableNames, self iVars keys", messageSends: [",", "keys", "iVars", "allVariableNames"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "bindingFor:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=smalltalk.MethodLexicalScope.superclass.fn.prototype._bindingFor_.apply(_st(self), [aNode]); if(($receiver = $2) == nil || $receiver == undefined){ $1=_st(self._iVars())._at_ifAbsent_(_st(aNode)._value(),(function(){ return smalltalk.withContext(function($ctx2) { return nil; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"bindingFor:",{aNode:aNode},smalltalk.MethodLexicalScope)})}, args: ["aNode"], source: "bindingFor: aNode\x0a\x09^ (super bindingFor: aNode) ifNil: [\x0a\x09\x09self iVars at: aNode value ifAbsent: [ nil ]]", messageSends: ["ifNil:", "at:ifAbsent:", "value", "iVars", "bindingFor:"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "canInlineNonLocalReturns", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"canInlineNonLocalReturns",{},smalltalk.MethodLexicalScope)})}, args: [], source: "canInlineNonLocalReturns\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "hasLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._localReturn(); return $1; }, function($ctx1) {$ctx1.fill(self,"hasLocalReturn",{},smalltalk.MethodLexicalScope)})}, args: [], source: "hasLocalReturn\x0a\x09^ self localReturn", messageSends: ["localReturn"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "hasNonLocalReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._nonLocalReturns())._notEmpty(); return $1; }, function($ctx1) {$ctx1.fill(self,"hasNonLocalReturn",{},smalltalk.MethodLexicalScope)})}, args: [], source: "hasNonLocalReturn\x0a\x09^ self nonLocalReturns notEmpty", messageSends: ["notEmpty", "nonLocalReturns"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "iVars", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@iVars"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@iVars"]=_st($Dictionary())._new(); $1=self["@iVars"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"iVars",{},smalltalk.MethodLexicalScope)})}, args: [], source: "iVars\x0a\x09^ iVars ifNil: [ iVars := Dictionary new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Dictionary"] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "isMethodScope", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isMethodScope",{},smalltalk.MethodLexicalScope)})}, args: [], source: "isMethodScope\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "localReturn", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@localReturn"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"localReturn",{},smalltalk.MethodLexicalScope)})}, args: [], source: "localReturn\x0a\x09^ localReturn ifNil: [ false ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "localReturn:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@localReturn"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"localReturn:",{aBoolean:aBoolean},smalltalk.MethodLexicalScope)})}, args: ["aBoolean"], source: "localReturn: aBoolean\x0a\x09localReturn := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "methodScope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self; return $1; }, function($ctx1) {$ctx1.fill(self,"methodScope",{},smalltalk.MethodLexicalScope)})}, args: [], source: "methodScope\x0a\x09^ self", messageSends: [], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "nonLocalReturns", category: 'accessing', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@nonLocalReturns"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@nonLocalReturns"]=_st($OrderedCollection())._new(); $1=self["@nonLocalReturns"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"nonLocalReturns",{},smalltalk.MethodLexicalScope)})}, args: [], source: "nonLocalReturns\x0a\x09^ nonLocalReturns ifNil: [ nonLocalReturns := OrderedCollection new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "pseudoVars", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} function $PseudoVar(){return smalltalk.PseudoVar||(typeof PseudoVar=="undefined"?nil:PseudoVar)} function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=self["@pseudoVars"]; if(($receiver = $1) == nil || $receiver == undefined){ self["@pseudoVars"]=_st($Dictionary())._new(); self["@pseudoVars"]; _st(_st(_st($Smalltalk())._current())._pseudoVariableNames())._do_((function(each){ return smalltalk.withContext(function($ctx2) { $2=_st($PseudoVar())._on_(each); _st($2)._scope_(self._methodScope()); $3=_st($2)._yourself(); return _st(self["@pseudoVars"])._at_put_(each,$3); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); } else { $1; }; $4=self["@pseudoVars"]; return $4; }, function($ctx1) {$ctx1.fill(self,"pseudoVars",{},smalltalk.MethodLexicalScope)})}, args: [], source: "pseudoVars\x0a\x09pseudoVars ifNil: [\x0a\x09\x09pseudoVars := Dictionary new.\x0a\x09\x09Smalltalk current pseudoVariableNames do: [ :each |\x0a\x09\x09\x09pseudoVars at: each put: ((PseudoVar on: each)\x0a\x09\x09\x09\x09scope: self methodScope;\x0a\x09\x09\x09\x09yourself) ]].\x0a\x09^ pseudoVars", messageSends: ["ifNil:", "new", "do:", "at:put:", "scope:", "methodScope", "on:", "yourself", "pseudoVariableNames", "current"], referencedClasses: ["Dictionary", "PseudoVar", "Smalltalk"] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "removeNonLocalReturn:", category: 'adding', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._nonLocalReturns())._remove_ifAbsent_(aScope,(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"removeNonLocalReturn:",{aScope:aScope},smalltalk.MethodLexicalScope)})}, args: ["aScope"], source: "removeNonLocalReturn: aScope\x0a\x09self nonLocalReturns remove: aScope ifAbsent: []", messageSends: ["remove:ifAbsent:", "nonLocalReturns"], referencedClasses: [] }), smalltalk.MethodLexicalScope); smalltalk.addMethod( smalltalk.method({ selector: "unknownVariables", category: 'accessing', fn: function (){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@unknownVariables"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@unknownVariables"]=_st($OrderedCollection())._new(); $1=self["@unknownVariables"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"unknownVariables",{},smalltalk.MethodLexicalScope)})}, args: [], source: "unknownVariables\x0a\x09^ unknownVariables ifNil: [ unknownVariables := OrderedCollection new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.MethodLexicalScope); smalltalk.addClass('ScopeVar', smalltalk.Object, ['scope', 'name'], 'Compiler-Semantic'); smalltalk.ScopeVar.comment="I am an entry in a LexicalScope that gets associated with variable nodes of the same name.\x0aThere are 4 different subclasses of vars: temp vars, local vars, args, and unknown/global vars."; smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._name())._asVariableName(); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.ScopeVar)})}, args: [], source: "alias\x0a\x09^ self name asVariableName", messageSends: ["asVariableName", "name"], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isArgVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isArgVar",{},smalltalk.ScopeVar)})}, args: [], source: "isArgVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isClassRefVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isClassRefVar",{},smalltalk.ScopeVar)})}, args: [], source: "isClassRefVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isInstanceVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isInstanceVar",{},smalltalk.ScopeVar)})}, args: [], source: "isInstanceVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isPseudoVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isPseudoVar",{},smalltalk.ScopeVar)})}, args: [], source: "isPseudoVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isTempVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isTempVar",{},smalltalk.ScopeVar)})}, args: [], source: "isTempVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "isUnknownVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isUnknownVar",{},smalltalk.ScopeVar)})}, args: [], source: "isUnknownVar\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "name", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@name"]; return $1; }, function($ctx1) {$ctx1.fill(self,"name",{},smalltalk.ScopeVar)})}, args: [], source: "name\x0a\x09^ name", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "name:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@name"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"name:",{aString:aString},smalltalk.ScopeVar)})}, args: ["aString"], source: "name: aString\x0a\x09name := aString", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "scope", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@scope"]; return $1; }, function($ctx1) {$ctx1.fill(self,"scope",{},smalltalk.ScopeVar)})}, args: [], source: "scope\x0a\x09^ scope", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "scope:", category: 'accessing', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { self["@scope"]=aScope; return self}, function($ctx1) {$ctx1.fill(self,"scope:",{aScope:aScope},smalltalk.ScopeVar)})}, args: ["aScope"], source: "scope: aScope\x0a\x09scope := aScope", messageSends: [], referencedClasses: [] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "validateAssignment", category: 'testing', fn: function (){ var self=this; function $InvalidAssignmentError(){return smalltalk.InvalidAssignmentError||(typeof InvalidAssignmentError=="undefined"?nil:InvalidAssignmentError)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(self._isArgVar())._or_((function(){ return smalltalk.withContext(function($ctx2) { return self._isPseudoVar(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($1)){ $2=_st($InvalidAssignmentError())._new(); _st($2)._variableName_(self._name()); $3=_st($2)._signal(); $3; }; return self}, function($ctx1) {$ctx1.fill(self,"validateAssignment",{},smalltalk.ScopeVar)})}, args: [], source: "validateAssignment\x0a\x09(self isArgVar or: [ self isPseudoVar ]) ifTrue: [\x0a\x09\x09InvalidAssignmentError new\x0a\x09\x09\x09variableName: self name;\x0a\x09\x09\x09signal]", messageSends: ["ifTrue:", "variableName:", "name", "new", "signal", "or:", "isPseudoVar", "isArgVar"], referencedClasses: ["InvalidAssignmentError"] }), smalltalk.ScopeVar); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._name_(aString); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{aString:aString},smalltalk.ScopeVar.klass)})}, args: ["aString"], source: "on: aString\x0a\x09^ self new\x0a\x09\x09name: aString;\x0a\x09\x09yourself", messageSends: ["name:", "new", "yourself"], referencedClasses: [] }), smalltalk.ScopeVar.klass); smalltalk.addClass('AliasVar', smalltalk.ScopeVar, ['node'], 'Compiler-Semantic'); smalltalk.AliasVar.comment="I am an internally defined variable by the compiler"; smalltalk.addMethod( smalltalk.method({ selector: "node", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@node"]; return $1; }, function($ctx1) {$ctx1.fill(self,"node",{},smalltalk.AliasVar)})}, args: [], source: "node\x0a\x09^ node", messageSends: [], referencedClasses: [] }), smalltalk.AliasVar); smalltalk.addMethod( smalltalk.method({ selector: "node:", category: 'accessing', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@node"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"node:",{aNode:aNode},smalltalk.AliasVar)})}, args: ["aNode"], source: "node: aNode\x0a\x09node := aNode", messageSends: [], referencedClasses: [] }), smalltalk.AliasVar); smalltalk.addClass('ArgVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.ArgVar.comment="I am an argument of a method or block."; smalltalk.addMethod( smalltalk.method({ selector: "isArgVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isArgVar",{},smalltalk.ArgVar)})}, args: [], source: "isArgVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.ArgVar); smalltalk.addClass('ClassRefVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.ClassRefVar.comment="I am an class reference variable"; smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("$".__comma(self._name())).__comma("()"); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.ClassRefVar)})}, args: [], source: "alias\x0a\x09\x22Fixes issue #190.\x0a\x09A function is created in the method definition, answering the class or nil.\x0a\x09See JSStream >> #nextPutClassRefFunction:\x22\x0a\x09\x0a\x09^ '$', self name, '()'", messageSends: [",", "name"], referencedClasses: [] }), smalltalk.ClassRefVar); smalltalk.addMethod( smalltalk.method({ selector: "isClassRefVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isClassRefVar",{},smalltalk.ClassRefVar)})}, args: [], source: "isClassRefVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.ClassRefVar); smalltalk.addClass('InstanceVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.InstanceVar.comment="I am an instance variable of a method or block."; smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st("self[\x22@".__comma(self._name())).__comma("\x22]"); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.InstanceVar)})}, args: [], source: "alias\x0a\x09^ 'self[\x22@', self name, '\x22]'", messageSends: [",", "name"], referencedClasses: [] }), smalltalk.InstanceVar); smalltalk.addMethod( smalltalk.method({ selector: "isInstanceVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isInstanceVar",{},smalltalk.InstanceVar)})}, args: [], source: "isInstanceVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.InstanceVar); smalltalk.addClass('PseudoVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.PseudoVar.comment="I am an pseudo variable.\x0a\x0aThe five Smalltalk pseudo variables are: 'self', 'super', 'nil', 'true' and 'false'"; smalltalk.addMethod( smalltalk.method({ selector: "alias", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._name(); return $1; }, function($ctx1) {$ctx1.fill(self,"alias",{},smalltalk.PseudoVar)})}, args: [], source: "alias\x0a\x09^ self name", messageSends: ["name"], referencedClasses: [] }), smalltalk.PseudoVar); smalltalk.addMethod( smalltalk.method({ selector: "isPseudoVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isPseudoVar",{},smalltalk.PseudoVar)})}, args: [], source: "isPseudoVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.PseudoVar); smalltalk.addClass('TempVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.TempVar.comment="I am an temporary variable of a method or block."; smalltalk.addMethod( smalltalk.method({ selector: "isTempVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isTempVar",{},smalltalk.TempVar)})}, args: [], source: "isTempVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.TempVar); smalltalk.addClass('UnknownVar', smalltalk.ScopeVar, [], 'Compiler-Semantic'); smalltalk.UnknownVar.comment="I am an unknown variable. Amber uses unknown variables as JavaScript globals"; smalltalk.addMethod( smalltalk.method({ selector: "isUnknownVar", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isUnknownVar",{},smalltalk.UnknownVar)})}, args: [], source: "isUnknownVar\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.UnknownVar); smalltalk.addClass('SemanticAnalyzer', smalltalk.NodeVisitor, ['currentScope', 'theClass', 'classReferences', 'messageSends', 'superSends'], 'Compiler-Semantic'); smalltalk.SemanticAnalyzer.comment="I semantically analyze the abstract syntax tree and annotate it with informations such as non local returns and variable scopes."; smalltalk.addMethod( smalltalk.method({ selector: "classReferences", category: 'accessing', fn: function (){ var self=this; function $Set(){return smalltalk.Set||(typeof Set=="undefined"?nil:Set)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@classReferences"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@classReferences"]=_st($Set())._new(); $1=self["@classReferences"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"classReferences",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "classReferences\x0a\x09^ classReferences ifNil: [ classReferences := Set new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Set"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "errorShadowingVariable:", category: 'error handling', fn: function (aString){ var self=this; function $ShadowingVariableError(){return smalltalk.ShadowingVariableError||(typeof ShadowingVariableError=="undefined"?nil:ShadowingVariableError)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st($ShadowingVariableError())._new(); _st($1)._variableName_(aString); $2=_st($1)._signal(); return self}, function($ctx1) {$ctx1.fill(self,"errorShadowingVariable:",{aString:aString},smalltalk.SemanticAnalyzer)})}, args: ["aString"], source: "errorShadowingVariable: aString\x0a\x09ShadowingVariableError new\x0a\x09\x09variableName: aString;\x0a\x09\x09signal", messageSends: ["variableName:", "new", "signal"], referencedClasses: ["ShadowingVariableError"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "errorUnknownVariable:", category: 'error handling', fn: function (aNode){ var self=this; var identifier; function $UnknownVariableError(){return smalltalk.UnknownVariableError||(typeof UnknownVariableError=="undefined"?nil:UnknownVariableError)} function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; identifier=_st(aNode)._value(); $1=_st(_st(_st(_st(_st($Smalltalk())._current())._globalJsVariables())._includes_(identifier))._not())._and_((function(){ return smalltalk.withContext(function($ctx2) { return self._isVariableGloballyUndefined_(identifier); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($1)){ $2=_st($UnknownVariableError())._new(); _st($2)._variableName_(_st(aNode)._value()); $3=_st($2)._signal(); $3; } else { _st(_st(_st(self["@currentScope"])._methodScope())._unknownVariables())._add_(_st(aNode)._value()); }; return self}, function($ctx1) {$ctx1.fill(self,"errorUnknownVariable:",{aNode:aNode,identifier:identifier},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "errorUnknownVariable: aNode\x0a\x09\x22Throw an error if the variable is undeclared in the global JS scope (i.e. window).\x0a\x09We allow all variables listed by Smalltalk>>#globalJsVariables.\x0a\x09This list includes: `jQuery`, `window`, `document`, `process` and `global`\x0a\x09for nodejs and browser environments.\x0a\x09\x0a\x09This is only to make sure compilation works on both browser-based and nodejs environments.\x0a\x09The ideal solution would be to use a pragma instead\x22\x0a\x0a\x09| identifier |\x0a\x09identifier := aNode value.\x0a\x09\x0a\x09((Smalltalk current globalJsVariables includes: identifier) not\x0a\x09\x09and: [ self isVariableGloballyUndefined: identifier ])\x0a\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09UnknownVariableError new\x0a\x09\x09\x09\x09\x09variableName: aNode value;\x0a\x09\x09\x09\x09\x09signal ]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09currentScope methodScope unknownVariables add: aNode value ]", messageSends: ["value", "ifTrue:ifFalse:", "variableName:", "new", "signal", "add:", "unknownVariables", "methodScope", "and:", "isVariableGloballyUndefined:", "not", "includes:", "globalJsVariables", "current"], referencedClasses: ["UnknownVariableError", "Smalltalk"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "isVariableGloballyUndefined:", category: 'testing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return eval('typeof ' + aString + ' == "undefined"'); return self}, function($ctx1) {$ctx1.fill(self,"isVariableGloballyUndefined:",{aString:aString},smalltalk.SemanticAnalyzer)})}, args: ["aString"], source: "isVariableGloballyUndefined: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "messageSends", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@messageSends"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@messageSends"]=_st($Dictionary())._new(); $1=self["@messageSends"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"messageSends",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "messageSends\x0a\x09^ messageSends ifNil: [ messageSends := Dictionary new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Dictionary"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "newBlockScope", category: 'factory', fn: function (){ var self=this; function $LexicalScope(){return smalltalk.LexicalScope||(typeof LexicalScope=="undefined"?nil:LexicalScope)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._newScopeOfClass_($LexicalScope()); return $1; }, function($ctx1) {$ctx1.fill(self,"newBlockScope",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "newBlockScope\x0a\x09^ self newScopeOfClass: LexicalScope", messageSends: ["newScopeOfClass:"], referencedClasses: ["LexicalScope"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "newMethodScope", category: 'factory', fn: function (){ var self=this; function $MethodLexicalScope(){return smalltalk.MethodLexicalScope||(typeof MethodLexicalScope=="undefined"?nil:MethodLexicalScope)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._newScopeOfClass_($MethodLexicalScope()); return $1; }, function($ctx1) {$ctx1.fill(self,"newMethodScope",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "newMethodScope\x0a\x09^ self newScopeOfClass: MethodLexicalScope", messageSends: ["newScopeOfClass:"], referencedClasses: ["MethodLexicalScope"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "newScopeOfClass:", category: 'factory', fn: function (aLexicalScopeClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=_st(aLexicalScopeClass)._new(); _st($2)._outerScope_(self["@currentScope"]); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"newScopeOfClass:",{aLexicalScopeClass:aLexicalScopeClass},smalltalk.SemanticAnalyzer)})}, args: ["aLexicalScopeClass"], source: "newScopeOfClass: aLexicalScopeClass\x0a\x09^ aLexicalScopeClass new\x0a\x09\x09outerScope: currentScope;\x0a\x09\x09yourself", messageSends: ["outerScope:", "new", "yourself"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "popScope", category: 'scope', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentScope"]; if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self["@currentScope"]=_st(self["@currentScope"])._outerScope(); self["@currentScope"]; }; return self}, function($ctx1) {$ctx1.fill(self,"popScope",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "popScope\x0a\x09currentScope ifNotNil: [\x0a\x09\x09currentScope := currentScope outerScope ]", messageSends: ["ifNotNil:", "outerScope"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "pushScope:", category: 'scope', fn: function (aScope){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aScope)._outerScope_(self["@currentScope"]); self["@currentScope"]=aScope; return self}, function($ctx1) {$ctx1.fill(self,"pushScope:",{aScope:aScope},smalltalk.SemanticAnalyzer)})}, args: ["aScope"], source: "pushScope: aScope\x0a\x09aScope outerScope: currentScope.\x0a\x09currentScope := aScope", messageSends: ["outerScope:"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "superSends", category: 'accessing', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@superSends"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@superSends"]=_st($Dictionary())._new(); $1=self["@superSends"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"superSends",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "superSends\x0a\x09^ superSends ifNil: [ superSends := Dictionary new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["Dictionary"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "theClass", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@theClass"]; return $1; }, function($ctx1) {$ctx1.fill(self,"theClass",{},smalltalk.SemanticAnalyzer)})}, args: [], source: "theClass\x0a\x09^ theClass", messageSends: [], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "theClass:", category: 'accessing', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { self["@theClass"]=aClass; return self}, function($ctx1) {$ctx1.fill(self,"theClass:",{aClass:aClass},smalltalk.SemanticAnalyzer)})}, args: ["aClass"], source: "theClass: aClass\x0a\x09theClass := aClass", messageSends: [], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "validateVariableScope:", category: 'scope', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@currentScope"])._lookupVariable_(aString); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { self._errorShadowingVariable_(aString); }; return self}, function($ctx1) {$ctx1.fill(self,"validateVariableScope:",{aString:aString},smalltalk.SemanticAnalyzer)})}, args: ["aString"], source: "validateVariableScope: aString\x0a\x09\x22Validate the variable scope in by doing a recursive lookup, up to the method scope\x22\x0a\x0a\x09(currentScope lookupVariable: aString) ifNotNil: [\x0a\x09\x09self errorShadowingVariable: aString ]", messageSends: ["ifNotNil:", "errorShadowingVariable:", "lookupVariable:"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitAssignmentNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitAssignmentNode_.apply(_st(self), [aNode]); _st(_st(aNode)._left())._beAssigned(); return self}, function($ctx1) {$ctx1.fill(self,"visitAssignmentNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitAssignmentNode: aNode\x0a\x09super visitAssignmentNode: aNode.\x0a\x09aNode left beAssigned", messageSends: ["visitAssignmentNode:", "beAssigned", "left"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitBlockNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self._pushScope_(self._newBlockScope()); _st(aNode)._scope_(self["@currentScope"]); _st(self["@currentScope"])._node_(aNode); _st(_st(aNode)._parameters())._do_((function(each){ return smalltalk.withContext(function($ctx2) { self._validateVariableScope_(each); return _st(self["@currentScope"])._addArg_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitBlockNode_.apply(_st(self), [aNode]); self._popScope(); return self}, function($ctx1) {$ctx1.fill(self,"visitBlockNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitBlockNode: aNode\x0a\x09self pushScope: self newBlockScope.\x0a\x09aNode scope: currentScope.\x0a\x09currentScope node: aNode.\x0a\x09\x0a\x09aNode parameters do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addArg: each ].\x0a\x0a\x09super visitBlockNode: aNode.\x0a\x09self popScope", messageSends: ["pushScope:", "newBlockScope", "scope:", "node:", "do:", "validateVariableScope:", "addArg:", "parameters", "visitBlockNode:", "popScope"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitCascadeNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._receiver_(_st(aNode)._receiver()); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitCascadeNode_.apply(_st(self), [aNode]); $1=_st(_st(_st(aNode)._nodes())._first())._superSend(); if(smalltalk.assert($1)){ _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._superSend_(true); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); }; return self}, function($ctx1) {$ctx1.fill(self,"visitCascadeNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitCascadeNode: aNode\x0a\x09\x22Populate the receiver into all children\x22\x0a\x09aNode nodes do: [ :each |\x0a\x09\x09each receiver: aNode receiver ].\x0a\x09super visitCascadeNode: aNode.\x0a\x09aNode nodes first superSend ifTrue: [\x0a\x09\x09aNode nodes do: [ :each | each superSend: true ]]", messageSends: ["do:", "receiver:", "receiver", "nodes", "visitCascadeNode:", "ifTrue:", "superSend:", "superSend", "first"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitClassReferenceNode:", category: 'visiting', fn: function (aNode){ var self=this; function $ClassRefVar(){return smalltalk.ClassRefVar||(typeof ClassRefVar=="undefined"?nil:ClassRefVar)} return smalltalk.withContext(function($ctx1) { var $1,$2; _st(self._classReferences())._add_(_st(aNode)._value()); $1=_st($ClassRefVar())._new(); _st($1)._name_(_st(aNode)._value()); $2=_st($1)._yourself(); _st(aNode)._binding_($2); return self}, function($ctx1) {$ctx1.fill(self,"visitClassReferenceNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitClassReferenceNode: aNode\x0a\x09self classReferences add: aNode value.\x0a\x09aNode binding: (ClassRefVar new name: aNode value; yourself)", messageSends: ["add:", "value", "classReferences", "binding:", "name:", "new", "yourself"], referencedClasses: ["ClassRefVar"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitMethodNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self._pushScope_(self._newMethodScope()); _st(aNode)._scope_(self["@currentScope"]); _st(self["@currentScope"])._node_(aNode); _st(_st(self._theClass())._allInstanceVariableNames())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(self["@currentScope"])._addIVar_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); _st(_st(aNode)._arguments())._do_((function(each){ return smalltalk.withContext(function($ctx2) { self._validateVariableScope_(each); return _st(self["@currentScope"])._addArg_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitMethodNode_.apply(_st(self), [aNode]); $1=aNode; _st($1)._classReferences_(self._classReferences()); _st($1)._messageSends_(_st(self._messageSends())._keys()); $2=_st($1)._superSends_(_st(self._superSends())._keys()); self._popScope(); return self}, function($ctx1) {$ctx1.fill(self,"visitMethodNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitMethodNode: aNode\x0a\x09self pushScope: self newMethodScope.\x0a\x09aNode scope: currentScope.\x0a\x09currentScope node: aNode.\x0a\x0a\x09self theClass allInstanceVariableNames do: [:each |\x0a\x09\x09currentScope addIVar: each ].\x0a\x09aNode arguments do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addArg: each ].\x0a\x0a\x09super visitMethodNode: aNode.\x0a\x0a\x09aNode\x0a\x09\x09classReferences: self classReferences;\x0a\x09\x09messageSends: self messageSends keys;\x0a\x09\x09superSends: self superSends keys.\x0a\x09self popScope", messageSends: ["pushScope:", "newMethodScope", "scope:", "node:", "do:", "addIVar:", "allInstanceVariableNames", "theClass", "validateVariableScope:", "addArg:", "arguments", "visitMethodNode:", "classReferences:", "classReferences", "messageSends:", "keys", "messageSends", "superSends:", "superSends", "popScope"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitReturnNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(aNode)._scope_(self["@currentScope"]); $1=_st(self["@currentScope"])._isMethodScope(); if(smalltalk.assert($1)){ _st(self["@currentScope"])._localReturn_(true); } else { _st(_st(self["@currentScope"])._methodScope())._addNonLocalReturn_(self["@currentScope"]); }; smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitReturnNode_.apply(_st(self), [aNode]); return self}, function($ctx1) {$ctx1.fill(self,"visitReturnNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitReturnNode: aNode\x0a\x09aNode scope: currentScope.\x0a\x09currentScope isMethodScope\x0a\x09\x09ifTrue: [ currentScope localReturn: true ]\x0a\x09\x09ifFalse: [ currentScope methodScope addNonLocalReturn: currentScope ].\x0a\x09super visitReturnNode: aNode", messageSends: ["scope:", "ifTrue:ifFalse:", "localReturn:", "addNonLocalReturn:", "methodScope", "isMethodScope", "visitReturnNode:"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitSendNode:", category: 'visiting', fn: function (aNode){ var self=this; function $Set(){return smalltalk.Set||(typeof Set=="undefined"?nil:Set)} function $IRSendInliner(){return smalltalk.IRSendInliner||(typeof IRSendInliner=="undefined"?nil:IRSendInliner)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(_st(_st(aNode)._receiver())._value()).__eq("super"); if(smalltalk.assert($1)){ _st(aNode)._superSend_(true); _st(_st(aNode)._receiver())._value_("self"); _st(self._superSends())._at_ifAbsentPut_(_st(aNode)._selector(),(function(){ return smalltalk.withContext(function($ctx2) { return _st($Set())._new(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(_st(self._superSends())._at_(_st(aNode)._selector()))._add_(aNode); } else { $2=_st(_st($IRSendInliner())._inlinedSelectors())._includes_(_st(aNode)._selector()); if(smalltalk.assert($2)){ _st(aNode)._shouldBeInlined_(true); _st(_st(aNode)._receiver())._shouldBeAliased_(true); }; }; _st(self._messageSends())._at_ifAbsentPut_(_st(aNode)._selector(),(function(){ return smalltalk.withContext(function($ctx2) { return _st($Set())._new(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(_st(self._messageSends())._at_(_st(aNode)._selector()))._add_(aNode); _st(aNode)._index_(_st(_st(self._messageSends())._at_(_st(aNode)._selector()))._size()); smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitSendNode_.apply(_st(self), [aNode]); return self}, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitSendNode: aNode\x0a\x0a\x09aNode receiver value = 'super'\x0a\x09\x09ifTrue: [\x0a\x09\x09\x09aNode superSend: true.\x0a\x09\x09\x09aNode receiver value: 'self'.\x0a\x09\x09\x09self superSends at: aNode selector ifAbsentPut: [ Set new ].\x0a\x09\x09\x09(self superSends at: aNode selector) add: aNode ]\x0a\x09\x09\x0a\x09\x09ifFalse: [ (IRSendInliner inlinedSelectors includes: aNode selector) ifTrue: [\x0a\x09\x09\x09aNode shouldBeInlined: true.\x0a\x09\x09\x09aNode receiver shouldBeAliased: true ] ].\x0a\x0a\x09self messageSends at: aNode selector ifAbsentPut: [ Set new ].\x0a\x09(self messageSends at: aNode selector) add: aNode.\x0a\x0a\x09aNode index: (self messageSends at: aNode selector) size.\x0a\x0a\x09super visitSendNode: aNode", messageSends: ["ifTrue:ifFalse:", "superSend:", "value:", "receiver", "at:ifAbsentPut:", "selector", "new", "superSends", "add:", "at:", "ifTrue:", "shouldBeInlined:", "shouldBeAliased:", "includes:", "inlinedSelectors", "=", "value", "messageSends", "index:", "size", "visitSendNode:"], referencedClasses: ["Set", "IRSendInliner"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitSequenceNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(aNode)._temps())._do_((function(each){ return smalltalk.withContext(function($ctx2) { self._validateVariableScope_(each); return _st(self["@currentScope"])._addTemp_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); smalltalk.SemanticAnalyzer.superclass.fn.prototype._visitSequenceNode_.apply(_st(self), [aNode]); return self}, function($ctx1) {$ctx1.fill(self,"visitSequenceNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitSequenceNode: aNode\x0a\x09aNode temps do: [ :each |\x0a\x09\x09self validateVariableScope: each.\x0a\x09\x09currentScope addTemp: each ].\x0a\x0a\x09super visitSequenceNode: aNode", messageSends: ["do:", "validateVariableScope:", "addTemp:", "temps", "visitSequenceNode:"], referencedClasses: [] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "visitVariableNode:", category: 'visiting', fn: function (aNode){ var self=this; function $UnknownVar(){return smalltalk.UnknownVar||(typeof UnknownVar=="undefined"?nil:UnknownVar)} return smalltalk.withContext(function($ctx1) { var $1,$3,$4,$5,$2; $1=aNode; $3=_st(self["@currentScope"])._lookupVariable_(aNode); if(($receiver = $3) == nil || $receiver == undefined){ self._errorUnknownVariable_(aNode); $4=_st($UnknownVar())._new(); _st($4)._name_(_st(aNode)._value()); $5=_st($4)._yourself(); $2=$5; } else { $2=$3; }; _st($1)._binding_($2); return self}, function($ctx1) {$ctx1.fill(self,"visitVariableNode:",{aNode:aNode},smalltalk.SemanticAnalyzer)})}, args: ["aNode"], source: "visitVariableNode: aNode\x0a\x09\x22Bind a ScopeVar to aNode by doing a lookup in the current scope.\x0a\x09If no ScopeVar is found, bind a UnknowVar and throw an error\x22\x0a\x0a\x09aNode binding: ((currentScope lookupVariable: aNode) ifNil: [\x0a\x09\x09self errorUnknownVariable: aNode.\x0a\x09\x09UnknownVar new name: aNode value; yourself ])", messageSends: ["binding:", "ifNil:", "errorUnknownVariable:", "name:", "value", "new", "yourself", "lookupVariable:"], referencedClasses: ["UnknownVar"] }), smalltalk.SemanticAnalyzer); smalltalk.addMethod( smalltalk.method({ selector: "on:", category: 'instance creation', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._theClass_(aClass); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"on:",{aClass:aClass},smalltalk.SemanticAnalyzer.klass)})}, args: ["aClass"], source: "on: aClass\x0a\x09^ self new\x0a\x09\x09theClass: aClass;\x0a\x09\x09yourself", messageSends: ["theClass:", "new", "yourself"], referencedClasses: [] }), smalltalk.SemanticAnalyzer.klass); }); define("amber_core/Compiler-Interpreter", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Compiler-Core", "amber_core/Kernel-Objects", "amber_core/Compiler-AST"], function(smalltalk,nil,_st){ smalltalk.addPackage('Compiler-Interpreter'); smalltalk.packages["Compiler-Interpreter"].transport = {"type":"amd","amdNamespace":"amber_core"}; smalltalk.addClass('AIContext', smalltalk.NodeVisitor, ['methodContext', 'outerContext', 'pc', 'locals', 'method'], 'Compiler-Interpreter'); smalltalk.AIContext.comment="I am like a `MethodContext`, used by the `ASTInterpreter`.\x0aUnlike a `MethodContext`, my instances are not read-only.\x0a\x0aWhen debugging, my instances are created by copying the current `MethodContext` (thisContext)"; smalltalk.addMethod( smalltalk.method({ selector: "asString", category: 'converting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@methodContext"])._asString(); return $1; }, function($ctx1) {$ctx1.fill(self,"asString",{},smalltalk.AIContext)})}, args: [], source: "asString\x0a\x09^ methodContext asString", messageSends: ["asString"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "home", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._isBlockContext(); if(smalltalk.assert($2)){ $1=_st(self._outerContext())._methodContext(); } else { $1=self; }; return $1; }, function($ctx1) {$ctx1.fill(self,"home",{},smalltalk.AIContext)})}, args: [], source: "home\x0a\x09^ self isBlockContext \x0a\x09\x09ifTrue: [ self outerContext methodContext ]\x0a\x09\x09ifFalse: [ self ]", messageSends: ["ifTrue:ifFalse:", "methodContext", "outerContext", "isBlockContext"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "initializeFromMethodContext:", category: 'initialization', fn: function (aMethodContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self["@methodContext"]=aMethodContext; self._pc_(_st(aMethodContext)._pc()); self._receiver_(_st(aMethodContext)._receiver()); self._method_(_st(aMethodContext)._method()); $1=_st(aMethodContext)._outerContext(); if(($receiver = $1) == nil || $receiver == undefined){ $1; } else { var outer; outer=$receiver; $2=_st(outer)._methodContext(); if(($receiver = $2) == nil || $receiver == undefined){ $2; } else { self._outerContext_(_st(self._class())._fromMethodContext_(_st(aMethodContext)._outerContext())); }; _st(_st(aMethodContext)._locals())._keysAndValuesDo_((function(key,value){ return smalltalk.withContext(function($ctx2) { return _st(self._locals())._at_put_(key,value); }, function($ctx2) {$ctx2.fillBlock({key:key,value:value},$ctx1)})})); }; return self}, function($ctx1) {$ctx1.fill(self,"initializeFromMethodContext:",{aMethodContext:aMethodContext},smalltalk.AIContext)})}, args: ["aMethodContext"], source: "initializeFromMethodContext: aMethodContext\x0a\x09methodContext := aMethodContext.\x0a\x09\x0a\x09self pc: aMethodContext pc.\x0a\x09self receiver: aMethodContext receiver.\x0a\x09self method: aMethodContext method.\x0a\x09aMethodContext outerContext ifNotNil: [ :outer |\x0a\x09\x09\x22If the method context is nil, the block was defined in JS, so ignore it\x22\x0a\x09\x09outer methodContext ifNotNil: [\x0a\x09\x09\x09self outerContext: (self class fromMethodContext: aMethodContext outerContext) ].\x0a\x09\x09\x09aMethodContext locals keysAndValuesDo: [ :key :value |\x0a\x09\x09\x09\x09self locals at: key put: value ] ]", messageSends: ["pc:", "pc", "receiver:", "receiver", "method:", "method", "ifNotNil:", "outerContext:", "fromMethodContext:", "outerContext", "class", "methodContext", "keysAndValuesDo:", "at:put:", "locals"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "initializeLocals", category: 'initialization', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { self["@locals"]=_st($Dictionary())._new(); _st(self["@locals"])._at_put_("thisContext",self); return self}, function($ctx1) {$ctx1.fill(self,"initializeLocals",{},smalltalk.AIContext)})}, args: [], source: "initializeLocals\x0a\x09locals := Dictionary new.\x0a\x09locals at: 'thisContext' put: self.", messageSends: ["new", "at:put:"], referencedClasses: ["Dictionary"] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "isBlockContext", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self["@methodContext"])._isBlockContext(); return $1; }, function($ctx1) {$ctx1.fill(self,"isBlockContext",{},smalltalk.AIContext)})}, args: [], source: "isBlockContext\x0a\x09^ methodContext isBlockContext", messageSends: ["isBlockContext"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "localAt:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._locals())._at_ifAbsent_(aString,(function(){ return smalltalk.withContext(function($ctx2) { return nil; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"localAt:",{aString:aString},smalltalk.AIContext)})}, args: ["aString"], source: "localAt: aString\x0a\x09^ self locals at: aString ifAbsent: [ nil ]", messageSends: ["at:ifAbsent:", "locals"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "localAt:put:", category: 'accessing', fn: function (aString,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._locals())._at_put_(aString,anObject); return self}, function($ctx1) {$ctx1.fill(self,"localAt:put:",{aString:aString,anObject:anObject},smalltalk.AIContext)})}, args: ["aString", "anObject"], source: "localAt: aString put: anObject\x0a\x09self locals at: aString put: anObject", messageSends: ["at:put:", "locals"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "locals", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self["@locals"]; if(($receiver = $1) == nil || $receiver == undefined){ self._initializeLocals(); } else { $1; }; $2=self["@locals"]; return $2; }, function($ctx1) {$ctx1.fill(self,"locals",{},smalltalk.AIContext)})}, args: [], source: "locals\x0a\x09locals ifNil: [ self initializeLocals ].\x0a\x09\x0a\x09^ locals", messageSends: ["ifNil:", "initializeLocals"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@method"]; return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.AIContext)})}, args: [], source: "method\x0a\x09^ method", messageSends: [], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "method:", category: 'accessing', fn: function (aCompiledMethod){ var self=this; return smalltalk.withContext(function($ctx1) { self["@method"]=aCompiledMethod; return self}, function($ctx1) {$ctx1.fill(self,"method:",{aCompiledMethod:aCompiledMethod},smalltalk.AIContext)})}, args: ["aCompiledMethod"], source: "method: aCompiledMethod\x0a\x09method := aCompiledMethod", messageSends: [], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "outerContext", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@outerContext"]; return $1; }, function($ctx1) {$ctx1.fill(self,"outerContext",{},smalltalk.AIContext)})}, args: [], source: "outerContext\x0a\x09^ outerContext", messageSends: [], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "outerContext:", category: 'accessing', fn: function (anAIContext){ var self=this; return smalltalk.withContext(function($ctx1) { self["@outerContext"]=anAIContext; return self}, function($ctx1) {$ctx1.fill(self,"outerContext:",{anAIContext:anAIContext},smalltalk.AIContext)})}, args: ["anAIContext"], source: "outerContext: anAIContext\x0a\x09outerContext := anAIContext", messageSends: [], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "pc", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@pc"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@pc"]=(0); $1=self["@pc"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"pc",{},smalltalk.AIContext)})}, args: [], source: "pc\x0a\x09^ pc ifNil: [ pc := 0 ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "pc:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@pc"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"pc:",{anInteger:anInteger},smalltalk.AIContext)})}, args: ["anInteger"], source: "pc: anInteger\x0a\x09pc := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "receiver", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self._localAt_("self"); return $1; }, function($ctx1) {$ctx1.fill(self,"receiver",{},smalltalk.AIContext)})}, args: [], source: "receiver\x0a\x09^ self localAt: 'self'", messageSends: ["localAt:"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "receiver:", category: 'accessing', fn: function (anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self._localAt_put_("self",anObject); return self}, function($ctx1) {$ctx1.fill(self,"receiver:",{anObject:anObject},smalltalk.AIContext)})}, args: ["anObject"], source: "receiver: anObject\x0a\x09self localAt: 'self' put: anObject", messageSends: ["localAt:put:"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "selector", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self._method(); if(($receiver = $2) == nil || $receiver == undefined){ $1=$2; } else { $1=_st(self._method())._selector(); }; return $1; }, function($ctx1) {$ctx1.fill(self,"selector",{},smalltalk.AIContext)})}, args: [], source: "selector\x0a\x09^ self method\x0a\x09\x09ifNotNil: [ self method selector ]", messageSends: ["ifNotNil:", "selector", "method"], referencedClasses: [] }), smalltalk.AIContext); smalltalk.addMethod( smalltalk.method({ selector: "fromMethodContext:", category: 'instance creation', fn: function (aMethodContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._initializeFromMethodContext_(aMethodContext); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"fromMethodContext:",{aMethodContext:aMethodContext},smalltalk.AIContext.klass)})}, args: ["aMethodContext"], source: "fromMethodContext: aMethodContext\x0a\x09^ self new\x0a\x09\x09initializeFromMethodContext: aMethodContext;\x0a\x09\x09yourself", messageSends: ["initializeFromMethodContext:", "new", "yourself"], referencedClasses: [] }), smalltalk.AIContext.klass); smalltalk.addClass('ASTDebugger', smalltalk.Object, ['interpreter', 'context'], 'Compiler-Interpreter'); smalltalk.ASTDebugger.comment="I am a stepping debugger interface for Amber code.\x0aI internally use an instance of `ASTSteppingInterpreter` to actually step through node and interpret them.\x0a\x0aMy instances are created from a `MethodContext` with `ASTDebugger class >> context:`.\x0aThey hold an `AIContext` instance internally, recursive copy of the `MethodContext`.\x0a\x0a## API\x0a\x0aUse the methods of the `'stepping'` protocol to do stepping."; smalltalk.addMethod( smalltalk.method({ selector: "atEnd", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._interpreter())._atEnd(); return $1; }, function($ctx1) {$ctx1.fill(self,"atEnd",{},smalltalk.ASTDebugger)})}, args: [], source: "atEnd\x0a\x09^ self interpreter atEnd", messageSends: ["atEnd", "interpreter"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "buildAST", category: 'initialization', fn: function (){ var self=this; var ast; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $SemanticAnalyzer(){return smalltalk.SemanticAnalyzer||(typeof SemanticAnalyzer=="undefined"?nil:SemanticAnalyzer)} return smalltalk.withContext(function($ctx1) { var $1; ast=_st(_st($Smalltalk())._current())._parse_(_st(self._method())._source()); _st(_st($SemanticAnalyzer())._on_(_st(_st(self._context())._receiver())._class()))._visit_(ast); $1=ast; return $1; }, function($ctx1) {$ctx1.fill(self,"buildAST",{ast:ast},smalltalk.ASTDebugger)})}, args: [], source: "buildAST\x0a\x09\x22Build the AST tree from the method source code.\x0a\x09The AST is annotated with a SemanticAnalyzer,\x0a\x09to know the semantics and bindings of each node needed for later debugging\x22\x0a\x09\x0a\x09| ast |\x0a\x09\x0a\x09ast := Smalltalk current parse: self method source.\x0a\x09(SemanticAnalyzer on: self context receiver class)\x0a\x09\x09visit: ast.\x0a\x09\x0a\x09^ ast", messageSends: ["parse:", "source", "method", "current", "visit:", "on:", "class", "receiver", "context"], referencedClasses: ["Smalltalk", "SemanticAnalyzer"] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "context", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@context"]; return $1; }, function($ctx1) {$ctx1.fill(self,"context",{},smalltalk.ASTDebugger)})}, args: [], source: "context\x0a\x09^ context", messageSends: [], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "context:", category: 'accessing', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { self["@context"]=aContext; return self}, function($ctx1) {$ctx1.fill(self,"context:",{aContext:aContext},smalltalk.ASTDebugger)})}, args: ["aContext"], source: "context: aContext\x0a\x09context := aContext", messageSends: [], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "defaultInterpreterClass", category: 'defaults', fn: function (){ var self=this; function $ASTSteppingInterpreter(){return smalltalk.ASTSteppingInterpreter||(typeof ASTSteppingInterpreter=="undefined"?nil:ASTSteppingInterpreter)} return smalltalk.withContext(function($ctx1) { var $1; $1=$ASTSteppingInterpreter(); return $1; }, function($ctx1) {$ctx1.fill(self,"defaultInterpreterClass",{},smalltalk.ASTDebugger)})}, args: [], source: "defaultInterpreterClass\x0a\x09^ ASTSteppingInterpreter", messageSends: [], referencedClasses: ["ASTSteppingInterpreter"] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "initializeInterpreter", category: 'initialization', fn: function (){ var self=this; var ast,next; function $ASTPCNodeVisitor(){return smalltalk.ASTPCNodeVisitor||(typeof ASTPCNodeVisitor=="undefined"?nil:ASTPCNodeVisitor)} return smalltalk.withContext(function($ctx1) { var $1,$2; ast=self._buildAST(); $1=_st($ASTPCNodeVisitor())._new(); _st($1)._context_(self._context()); _st($1)._visit_(ast); $2=_st($1)._currentNode(); next=$2; _st(self._interpreter())._interpret_(next); return self}, function($ctx1) {$ctx1.fill(self,"initializeInterpreter",{ast:ast,next:next},smalltalk.ASTDebugger)})}, args: [], source: "initializeInterpreter\x0a\x09| ast next |\x0a\x09ast := self buildAST.\x0a\x09next := ASTPCNodeVisitor new\x0a\x09\x09context: self context;\x0a\x09\x09visit: ast;\x0a\x09\x09currentNode.\x0a\x09self interpreter interpret: next", messageSends: ["buildAST", "context:", "context", "new", "visit:", "currentNode", "interpret:", "interpreter"], referencedClasses: ["ASTPCNodeVisitor"] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "initializeWithContext:", category: 'initialization', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { self._context_(aContext); self._initializeInterpreter(); return self}, function($ctx1) {$ctx1.fill(self,"initializeWithContext:",{aContext:aContext},smalltalk.ASTDebugger)})}, args: ["aContext"], source: "initializeWithContext: aContext\x0a\x09\x22TODO: do we need to handle block contexts?\x22\x0a\x09\x0a\x09self context: aContext.\x0a\x09self initializeInterpreter", messageSends: ["context:", "initializeInterpreter"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "interpreter", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@interpreter"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@interpreter"]=_st(self._defaultInterpreterClass())._new(); $1=self["@interpreter"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter",{},smalltalk.ASTDebugger)})}, args: [], source: "interpreter\x0a\x09^ interpreter ifNil: [ interpreter := self defaultInterpreterClass new ]", messageSends: ["ifNil:", "new", "defaultInterpreterClass"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:", category: 'accessing', fn: function (anInterpreter){ var self=this; return smalltalk.withContext(function($ctx1) { self["@interpreter"]=anInterpreter; return self}, function($ctx1) {$ctx1.fill(self,"interpreter:",{anInterpreter:anInterpreter},smalltalk.ASTDebugger)})}, args: ["anInterpreter"], source: "interpreter: anInterpreter\x0a\x09interpreter := anInterpreter", messageSends: [], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "method", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._context())._method(); return $1; }, function($ctx1) {$ctx1.fill(self,"method",{},smalltalk.ASTDebugger)})}, args: [], source: "method\x0a\x09^ self context method", messageSends: ["method", "context"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "nextNode", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._interpreter())._nextNode(); return $1; }, function($ctx1) {$ctx1.fill(self,"nextNode",{},smalltalk.ASTDebugger)})}, args: [], source: "nextNode\x0a\x09^ self interpreter nextNode", messageSends: ["nextNode", "interpreter"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "proceed", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldBeImplemented(); return self}, function($ctx1) {$ctx1.fill(self,"proceed",{},smalltalk.ASTDebugger)})}, args: [], source: "proceed\x0a\x09self shouldBeImplemented", messageSends: ["shouldBeImplemented"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "restart", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldBeImplemented(); return self}, function($ctx1) {$ctx1.fill(self,"restart",{},smalltalk.ASTDebugger)})}, args: [], source: "restart\x0a\x09self shouldBeImplemented", messageSends: ["shouldBeImplemented"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "step", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(_st(self._interpreter())._nextNode())._notNil())._and_((function(){ return smalltalk.withContext(function($ctx3) { return _st(_st(self._interpreter())._nextNode())._stopOnStepping(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})))._or_((function(){ return smalltalk.withContext(function($ctx3) { return _st(_st(self._interpreter())._atEnd())._not(); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileFalse_((function(){ return smalltalk.withContext(function($ctx2) { _st(self._interpreter())._step(); return self._step(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"step",{},smalltalk.ASTDebugger)})}, args: [], source: "step\x0a\x09\x22The ASTSteppingInterpreter stops at each node interpretation.\x0a\x09One step will interpret nodes until:\x0a\x09- we get at the end\x0a\x09- the next node is a stepping node (send, assignment, etc.)\x22\x0a\x09\x0a\x09[ (self interpreter nextNode notNil and: [ self interpreter nextNode stopOnStepping ])\x0a\x09\x09or: [ self interpreter atEnd not ] ]\x0a\x09\x09\x09whileFalse: [\x0a\x09\x09\x09\x09self interpreter step.\x0a\x09\x09\x09\x09self step ]", messageSends: ["whileFalse:", "step", "interpreter", "or:", "not", "atEnd", "and:", "stopOnStepping", "nextNode", "notNil"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "stepInto", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._shouldBeImplemented(); return self}, function($ctx1) {$ctx1.fill(self,"stepInto",{},smalltalk.ASTDebugger)})}, args: [], source: "stepInto\x0a\x09self shouldBeImplemented", messageSends: ["shouldBeImplemented"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "stepOver", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { self._step(); return self}, function($ctx1) {$ctx1.fill(self,"stepOver",{},smalltalk.ASTDebugger)})}, args: [], source: "stepOver\x0a\x09self step", messageSends: ["step"], referencedClasses: [] }), smalltalk.ASTDebugger); smalltalk.addMethod( smalltalk.method({ selector: "context:", category: 'instance creation', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$1; $2=self._new(); _st($2)._initializeWithContext_(aContext); $3=_st($2)._yourself(); $1=$3; return $1; }, function($ctx1) {$ctx1.fill(self,"context:",{aContext:aContext},smalltalk.ASTDebugger.klass)})}, args: ["aContext"], source: "context: aContext\x0a\x09^ self new\x0a\x09\x09initializeWithContext: aContext;\x0a\x09\x09yourself", messageSends: ["initializeWithContext:", "new", "yourself"], referencedClasses: [] }), smalltalk.ASTDebugger.klass); smalltalk.addClass('ASTInterpreter', smalltalk.Object, ['currentNode', 'context', 'shouldReturn', 'result'], 'Compiler-Interpreter'); smalltalk.ASTInterpreter.comment="I am like a `NodeVisitor`, interpreting nodes one after each other.\x0aI am built using Continuation Passing Style for stepping purposes.\x0a\x0a## Usage example:\x0a\x0a\x09| ast interpreter |\x0a\x09ast := Smalltalk current parse: 'foo 1+2+4'.\x0a\x09(SemanticAnalyzer on: Object) visit: ast.\x0a\x0a\x09ASTInterpreter new\x0a\x09\x09interpret: ast nodes first;\x0a\x09\x09result \x22Answers 7\x22"; smalltalk.addMethod( smalltalk.method({ selector: "assign:to:", category: 'private', fn: function (aNode,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st(aNode)._binding())._isInstanceVar(); if(smalltalk.assert($2)){ $1=_st(_st(self._context())._receiver())._instVarAt_put_(_st(aNode)._value(),anObject); } else { $1=_st(self._context())._localAt_put_(_st(aNode)._value(),anObject); }; return $1; }, function($ctx1) {$ctx1.fill(self,"assign:to:",{aNode:aNode,anObject:anObject},smalltalk.ASTInterpreter)})}, args: ["aNode", "anObject"], source: "assign: aNode to: anObject\x0a\x09^ aNode binding isInstanceVar\x0a\x09\x09ifTrue: [ self context receiver instVarAt: aNode value put: anObject ]\x0a\x09\x09ifFalse: [ self context localAt: aNode value put: anObject ]", messageSends: ["ifTrue:ifFalse:", "instVarAt:put:", "value", "receiver", "context", "localAt:put:", "isInstanceVar", "binding"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "context", category: 'accessing', fn: function (){ var self=this; function $AIContext(){return smalltalk.AIContext||(typeof AIContext=="undefined"?nil:AIContext)} return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@context"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@context"]=_st($AIContext())._new(); $1=self["@context"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"context",{},smalltalk.ASTInterpreter)})}, args: [], source: "context\x0a\x09^ context ifNil: [ context := AIContext new ]", messageSends: ["ifNil:", "new"], referencedClasses: ["AIContext"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "context:", category: 'accessing', fn: function (anAIContext){ var self=this; return smalltalk.withContext(function($ctx1) { self["@context"]=anAIContext; return self}, function($ctx1) {$ctx1.fill(self,"context:",{anAIContext:anAIContext},smalltalk.ASTInterpreter)})}, args: ["anAIContext"], source: "context: anAIContext\x0a\x09context := anAIContext", messageSends: [], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "continue:value:", category: 'private', fn: function (aBlock,anObject){ var self=this; return smalltalk.withContext(function($ctx1) { self["@result"]=anObject; _st(aBlock)._value_(anObject); return self}, function($ctx1) {$ctx1.fill(self,"continue:value:",{aBlock:aBlock,anObject:anObject},smalltalk.ASTInterpreter)})}, args: ["aBlock", "anObject"], source: "continue: aBlock value: anObject\x0a\x09result := anObject.\x0a\x09aBlock value: anObject", messageSends: ["value:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "currentNode", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentNode"]; return $1; }, function($ctx1) {$ctx1.fill(self,"currentNode",{},smalltalk.ASTInterpreter)})}, args: [], source: "currentNode\x0a\x09^ currentNode", messageSends: [], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "eval:", category: 'private', fn: function (aString){ var self=this; var source,function_; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; source=_st($String())._streamContents_((function(str){ return smalltalk.withContext(function($ctx2) { _st(str)._nextPutAll_("(function("); _st(_st(_st(self._context())._locals())._keys())._do_separatedBy_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(str)._nextPutAll_(each); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})}),(function(){ return smalltalk.withContext(function($ctx3) { return _st(str)._nextPutAll_(","); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); $1=str; _st($1)._nextPutAll_("){ return (function() {"); _st($1)._nextPutAll_(aString); $2=_st($1)._nextPutAll_("})() })"); return $2; }, function($ctx2) {$ctx2.fillBlock({str:str},$ctx1)})})); function_=_st(_st($Compiler())._new())._eval_(source); $3=_st(function_)._valueWithPossibleArguments_(_st(_st(self._context())._locals())._values()); return $3; }, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString,source:source,function_:function_},smalltalk.ASTInterpreter)})}, args: ["aString"], source: "eval: aString\x0a\x09\x22Evaluate aString as JS source inside an JS function.\x0a\x09aString is not sandboxed.\x22\x0a\x09\x0a\x09| source function |\x0a\x09\x0a\x09source := String streamContents: [ :str |\x0a\x09\x09str nextPutAll: '(function('.\x0a\x09\x09self context locals keys\x0a\x09\x09\x09do: [ :each | str nextPutAll: each ]\x0a\x09\x09\x09separatedBy: [ str nextPutAll: ',' ].\x0a\x09\x09str\x0a\x09\x09\x09nextPutAll: '){ return (function() {';\x0a\x09\x09\x09nextPutAll: aString;\x0a\x09\x09\x09nextPutAll: '})() })' ].\x0a\x09\x09\x09\x0a\x09function := Compiler new eval: source.\x0a\x09\x0a\x09^ function valueWithPossibleArguments: self context locals values", messageSends: ["streamContents:", "nextPutAll:", "do:separatedBy:", "keys", "locals", "context", "eval:", "new", "valueWithPossibleArguments:", "values"], referencedClasses: ["String", "Compiler"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.ASTInterpreter.superclass.fn.prototype._initialize.apply(_st(self), []); self["@shouldReturn"]=false; return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ASTInterpreter)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09shouldReturn := false", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpret:", category: 'interpreting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@shouldReturn"]=false; self._interpret_continue_(aNode,(function(value){ return smalltalk.withContext(function($ctx2) { self["@result"]=value; return self["@result"]; }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpret:",{aNode:aNode},smalltalk.ASTInterpreter)})}, args: ["aNode"], source: "interpret: aNode\x0a\x09shouldReturn := false.\x0a\x09self interpret: aNode continue: [ :value |\x0a\x09\x09result := value ]", messageSends: ["interpret:continue:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpret:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=self["@shouldReturn"]; if(smalltalk.assert($1)){ $2=self; return $2; }; $3=_st(aNode)._isNode(); if(smalltalk.assert($3)){ self["@currentNode"]=aNode; self["@currentNode"]; self._interpretNode_continue_(aNode,(function(value){ return smalltalk.withContext(function($ctx2) { return self._continue_value_(aBlock,value); }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); } else { self._continue_value_(aBlock,aNode); }; return self}, function($ctx1) {$ctx1.fill(self,"interpret:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpret: aNode continue: aBlock\x0a\x09shouldReturn ifTrue: [ ^ self ].\x0a\x0a\x09aNode isNode\x0a\x09\x09ifTrue: [\x0a\x09\x09\x09currentNode := aNode.\x0a\x09\x09\x09self interpretNode: aNode continue: [ :value |\x0a\x09\x09\x09\x09self continue: aBlock value: value ] ]\x0a\x09\x09ifFalse: [ self continue: aBlock value: aNode ]", messageSends: ["ifTrue:", "ifTrue:ifFalse:", "interpretNode:continue:", "continue:value:", "isNode"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretAll:continue:", category: 'private', fn: function (aCollection,aBlock){ var self=this; function $OrderedCollection(){return smalltalk.OrderedCollection||(typeof OrderedCollection=="undefined"?nil:OrderedCollection)} return smalltalk.withContext(function($ctx1) { self._interpretAll_continue_result_(aCollection,aBlock,_st($OrderedCollection())._new()); return self}, function($ctx1) {$ctx1.fill(self,"interpretAll:continue:",{aCollection:aCollection,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aCollection", "aBlock"], source: "interpretAll: aCollection continue: aBlock\x0a\x09self\x0a\x09\x09interpretAll: aCollection\x0a\x09\x09continue: aBlock\x0a\x09\x09result: OrderedCollection new", messageSends: ["interpretAll:continue:result:", "new"], referencedClasses: ["OrderedCollection"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretAll:continue:result:", category: 'private', fn: function (nodes,aBlock,aCollection){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(nodes)._isEmpty(); if(smalltalk.assert($1)){ self._continue_value_(aBlock,aCollection); } else { self._interpret_continue_(_st(nodes)._first(),(function(value){ return smalltalk.withContext(function($ctx2) { return self._interpretAll_continue_result_(_st(nodes)._allButFirst(),aBlock,_st(aCollection).__comma([value])); }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); }; return self}, function($ctx1) {$ctx1.fill(self,"interpretAll:continue:result:",{nodes:nodes,aBlock:aBlock,aCollection:aCollection},smalltalk.ASTInterpreter)})}, args: ["nodes", "aBlock", "aCollection"], source: "interpretAll: nodes continue: aBlock result: aCollection\x0a\x09nodes isEmpty\x0a\x09\x09ifTrue: [ self continue: aBlock value: aCollection ]\x0a\x09\x09ifFalse: [\x0a\x09\x09\x09self interpret: nodes first continue: [:value |\x0a\x09\x09\x09\x09self\x0a\x09\x09\x09\x09\x09interpretAll: nodes allButFirst\x0a\x09\x09\x09\x09\x09continue: aBlock\x0a\x09\x09\x09\x09\x09result: aCollection, { value } ] ]", messageSends: ["ifTrue:ifFalse:", "continue:value:", "interpret:continue:", "first", "interpretAll:continue:result:", "allButFirst", ",", "isEmpty"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretAssignmentNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpret_continue_(_st(aNode)._right(),(function(value){ return smalltalk.withContext(function($ctx2) { return self._continue_value_(aBlock,self._assign_to_(_st(aNode)._left(),value)); }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretAssignmentNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretAssignmentNode: aNode continue: aBlock\x0a\x09self interpret: aNode right continue: [ :value |\x0a\x09\x09self\x0a\x09\x09\x09continue: aBlock\x0a\x09\x09\x09value: (self assign: aNode left to: value) ]", messageSends: ["interpret:continue:", "right", "continue:value:", "assign:to:", "left"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretBlockNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self._continue_value_(aBlock,(function(){ return smalltalk.withContext(function($ctx2) { return self._withBlockContext_((function(){ return smalltalk.withContext(function($ctx3) { $1=self; _st($1)._interpret_(_st(_st(aNode)._nodes())._first()); $2=_st($1)._result(); return $2; }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretBlockNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretBlockNode: aNode continue: aBlock\x0a\x09self\x0a\x09\x09continue: aBlock\x0a\x09\x09value: [ \x0a\x09\x09\x09self withBlockContext: [ \x0a\x09\x09\x09\x09self interpret: aNode nodes first; result ] ]", messageSends: ["continue:value:", "withBlockContext:", "interpret:", "first", "nodes", "result"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretBlockSequenceNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpretSequenceNode_continue_(aNode,aBlock); return self}, function($ctx1) {$ctx1.fill(self,"interpretBlockSequenceNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretBlockSequenceNode: aNode continue: aBlock\x0a\x09self interpretSequenceNode: aNode continue: aBlock", messageSends: ["interpretSequenceNode:continue:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretCascadeNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpret_continue_(_st(aNode)._receiver(),(function(receiver){ return smalltalk.withContext(function($ctx2) { _st(_st(aNode)._nodes())._do_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(each)._receiver_(receiver); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})})); return self._interpretAll_continue_(_st(_st(aNode)._nodes())._allButLast(),(function(){ return smalltalk.withContext(function($ctx3) { return self._interpret_continue_(_st(_st(aNode)._nodes())._last(),(function(val){ return smalltalk.withContext(function($ctx4) { return self._continue_value_(aBlock,val); }, function($ctx4) {$ctx4.fillBlock({val:val},$ctx3)})})); }, function($ctx3) {$ctx3.fillBlock({},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({receiver:receiver},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretCascadeNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretCascadeNode: aNode continue: aBlock\x0a\x09\x22TODO: Handle super sends\x22\x0a\x09\x0a\x09self interpret: aNode receiver continue: [ :receiver |\x0a\x09\x09\x22Only interpret the receiver once\x22\x0a\x09\x09aNode nodes do: [ :each | each receiver: receiver ].\x0a\x0a\x09\x09self\x0a\x09\x09\x09interpretAll: aNode nodes allButLast\x0a\x09\x09\x09continue: [\x0a\x09\x09\x09\x09self\x0a\x09\x09\x09\x09\x09interpret: aNode nodes last\x0a\x09\x09\x09\x09\x09continue: [ :val | self continue: aBlock value: val ] ] ]", messageSends: ["interpret:continue:", "receiver", "do:", "receiver:", "nodes", "interpretAll:continue:", "allButLast", "last", "continue:value:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretClassReferenceNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} return smalltalk.withContext(function($ctx1) { self._continue_value_(aBlock,_st(_st($Smalltalk())._current())._at_(_st(aNode)._value())); return self}, function($ctx1) {$ctx1.fill(self,"interpretClassReferenceNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretClassReferenceNode: aNode continue: aBlock\x0a\x09self continue: aBlock value: (Smalltalk current at: aNode value)", messageSends: ["continue:value:", "at:", "value", "current"], referencedClasses: ["Smalltalk"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretDynamicArrayNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpretAll_continue_(_st(aNode)._nodes(),(function(array){ return smalltalk.withContext(function($ctx2) { return self._continue_value_(aBlock,array); }, function($ctx2) {$ctx2.fillBlock({array:array},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretDynamicArrayNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretDynamicArrayNode: aNode continue: aBlock\x0a\x09self interpretAll: aNode nodes continue: [ :array |\x0a\x09\x09self\x0a\x09\x09\x09continue: aBlock\x0a\x09\x09\x09value: array ]", messageSends: ["interpretAll:continue:", "nodes", "continue:value:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretDynamicDictionaryNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; function $HashedCollection(){return smalltalk.HashedCollection||(typeof HashedCollection=="undefined"?nil:HashedCollection)} return smalltalk.withContext(function($ctx1) { self._interpretAll_continue_(_st(aNode)._nodes(),(function(array){ var hashedCollection; return smalltalk.withContext(function($ctx2) { hashedCollection=_st($HashedCollection())._new(); hashedCollection; _st(array)._do_((function(each){ return smalltalk.withContext(function($ctx3) { return _st(hashedCollection)._add_(each); }, function($ctx3) {$ctx3.fillBlock({each:each},$ctx2)})})); return self._continue_value_(aBlock,hashedCollection); }, function($ctx2) {$ctx2.fillBlock({array:array,hashedCollection:hashedCollection},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretDynamicDictionaryNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretDynamicDictionaryNode: aNode continue: aBlock\x0a\x09self interpretAll: aNode nodes continue: [ :array | | hashedCollection |\x0a\x09\x09hashedCollection := HashedCollection new.\x0a\x09\x09array do: [ :each | hashedCollection add: each ].\x0a\x09\x09self\x0a\x09\x09\x09continue: aBlock\x0a\x09\x09\x09value: hashedCollection ]", messageSends: ["interpretAll:continue:", "nodes", "new", "do:", "add:", "continue:value:"], referencedClasses: ["HashedCollection"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretJSStatementNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self["@shouldReturn"]=true; self._continue_value_(aBlock,self._eval_(_st(aNode)._source())); return self}, function($ctx1) {$ctx1.fill(self,"interpretJSStatementNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretJSStatementNode: aNode continue: aBlock\x0a\x09shouldReturn := true.\x0a\x09self continue: aBlock value: (self eval: aNode source)", messageSends: ["continue:value:", "eval:", "source"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretMethodNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpretAll_continue_(_st(aNode)._nodes(),(function(array){ return smalltalk.withContext(function($ctx2) { return self._continue_value_(aBlock,_st(array)._first()); }, function($ctx2) {$ctx2.fillBlock({array:array},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretMethodNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretMethodNode: aNode continue: aBlock\x0a\x09self interpretAll: aNode nodes continue: [ :array |\x0a\x09\x09self continue: aBlock value: array first ]", messageSends: ["interpretAll:continue:", "nodes", "continue:value:", "first"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aNode)._interpreter_continue_(self,aBlock); return self}, function($ctx1) {$ctx1.fill(self,"interpretNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretNode: aNode continue: aBlock\x0a\x09aNode interpreter: self continue: aBlock", messageSends: ["interpreter:continue:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretReturnNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpret_continue_(_st(_st(aNode)._nodes())._first(),(function(value){ return smalltalk.withContext(function($ctx2) { self["@shouldReturn"]=true; self["@shouldReturn"]; return self._continue_value_(aBlock,value); }, function($ctx2) {$ctx2.fillBlock({value:value},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretReturnNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretReturnNode: aNode continue: aBlock\x0a\x09self interpret: aNode nodes first continue: [ :value |\x0a\x09\x09shouldReturn := true.\x0a\x09\x09self continue: aBlock value: value ]", messageSends: ["interpret:continue:", "first", "nodes", "continue:value:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretSendNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpret_continue_(_st(aNode)._receiver(),(function(receiver){ return smalltalk.withContext(function($ctx2) { return self._interpretAll_continue_(_st(aNode)._arguments(),(function(args){ return smalltalk.withContext(function($ctx3) { return self._messageFromSendNode_arguments_do_(aNode,args,(function(message){ return smalltalk.withContext(function($ctx4) { _st(self._context())._pc_(_st(_st(self._context())._pc()).__plus((1))); return self._continue_value_(aBlock,self._sendMessage_to_superSend_(message,receiver,_st(aNode)._superSend())); }, function($ctx4) {$ctx4.fillBlock({message:message},$ctx3)})})); }, function($ctx3) {$ctx3.fillBlock({args:args},$ctx2)})})); }, function($ctx2) {$ctx2.fillBlock({receiver:receiver},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretSendNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretSendNode: aNode continue: aBlock\x0a\x09self interpret: aNode receiver continue: [ :receiver |\x0a\x09\x09self interpretAll: aNode arguments continue: [ :args |\x0a\x09\x09\x09self\x0a\x09\x09\x09\x09messageFromSendNode: aNode\x0a\x09\x09\x09\x09arguments: args\x0a\x09\x09\x09\x09do: [ :message |\x0a\x09\x09\x09\x09\x09self context pc: self context pc + 1.\x0a\x09\x09\x09\x09\x09self\x0a\x09\x09\x09\x09\x09\x09continue: aBlock\x0a\x09\x09\x09\x09\x09\x09value: (self sendMessage: message to: receiver superSend: aNode superSend) ] ] ]", messageSends: ["interpret:continue:", "receiver", "interpretAll:continue:", "arguments", "messageFromSendNode:arguments:do:", "pc:", "+", "pc", "context", "continue:value:", "sendMessage:to:superSend:", "superSend"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretSequenceNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._interpretAll_continue_(_st(aNode)._nodes(),(function(array){ return smalltalk.withContext(function($ctx2) { return self._continue_value_(aBlock,_st(array)._last()); }, function($ctx2) {$ctx2.fillBlock({array:array},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"interpretSequenceNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretSequenceNode: aNode continue: aBlock\x0a\x09self interpretAll: aNode nodes continue: [ :array |\x0a\x09\x09self continue: aBlock value: array last ]", messageSends: ["interpretAll:continue:", "nodes", "continue:value:", "last"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretValueNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self._continue_value_(aBlock,_st(aNode)._value()); return self}, function($ctx1) {$ctx1.fill(self,"interpretValueNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretValueNode: aNode continue: aBlock\x0a\x09self continue: aBlock value: aNode value", messageSends: ["continue:value:", "value"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpretVariableNode:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$4,$3; $1=self; $2=aBlock; $4=_st(_st(aNode)._binding())._isInstanceVar(); if(smalltalk.assert($4)){ $3=_st(_st(self._context())._receiver())._instVarAt_(_st(aNode)._value()); } else { $3=_st(self._context())._localAt_(_st(aNode)._value()); }; _st($1)._continue_value_($2,$3); return self}, function($ctx1) {$ctx1.fill(self,"interpretVariableNode:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aNode", "aBlock"], source: "interpretVariableNode: aNode continue: aBlock\x0a\x09self\x0a\x09\x09continue: aBlock\x0a\x09\x09value: (aNode binding isInstanceVar\x0a\x09\x09\x09ifTrue: [ self context receiver instVarAt: aNode value ]\x0a\x09\x09\x09ifFalse: [ self context localAt: aNode value ])", messageSends: ["continue:value:", "ifTrue:ifFalse:", "instVarAt:", "value", "receiver", "context", "localAt:", "isInstanceVar", "binding"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "messageFromSendNode:arguments:do:", category: 'private', fn: function (aSendNode,aCollection,aBlock){ var self=this; function $Message(){return smalltalk.Message||(typeof Message=="undefined"?nil:Message)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st($Message())._new(); _st($1)._selector_(_st(aSendNode)._selector()); _st($1)._arguments_(aCollection); $2=_st($1)._yourself(); self._continue_value_(aBlock,$2); return self}, function($ctx1) {$ctx1.fill(self,"messageFromSendNode:arguments:do:",{aSendNode:aSendNode,aCollection:aCollection,aBlock:aBlock},smalltalk.ASTInterpreter)})}, args: ["aSendNode", "aCollection", "aBlock"], source: "messageFromSendNode: aSendNode arguments: aCollection do: aBlock\x0a\x09self\x0a\x09\x09continue: aBlock\x0a\x09\x09value: (Message new\x0a\x09\x09\x09selector: aSendNode selector;\x0a\x09\x09\x09arguments: aCollection;\x0a\x09\x09\x09yourself)", messageSends: ["continue:value:", "selector:", "selector", "new", "arguments:", "yourself"], referencedClasses: ["Message"] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "result", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@result"]; return $1; }, function($ctx1) {$ctx1.fill(self,"result",{},smalltalk.ASTInterpreter)})}, args: [], source: "result\x0a\x09^ result", messageSends: [], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "sendMessage:to:superSend:", category: 'private', fn: function (aMessage,anObject,aBoolean){ var self=this; var method; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5,$6; var $early={}; try { $1=aBoolean; if(! smalltalk.assert($1)){ $2=_st(aMessage)._sendTo_(anObject); return $2; }; $3=_st(_st(anObject)._class())._superclass(); if(($receiver = $3) == nil || $receiver == undefined){ $4=self._messageNotUnderstood_receiver_(aMessage,anObject); return $4; } else { $3; }; method=_st(_st(_st(_st(anObject)._class())._superclass())._methodDictionary())._at_ifAbsent_(_st(aMessage)._selector(),(function(){ return smalltalk.withContext(function($ctx2) { $5=self._messageNotUnderstood_receiver_(aMessage,anObject); throw $early=[$5]; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $6=_st(_st(method)._fn())._applyTo_arguments_(anObject,_st(aMessage)._arguments()); return $6; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"sendMessage:to:superSend:",{aMessage:aMessage,anObject:anObject,aBoolean:aBoolean,method:method},smalltalk.ASTInterpreter)})}, args: ["aMessage", "anObject", "aBoolean"], source: "sendMessage: aMessage to: anObject superSend: aBoolean\x0a\x09| method |\x0a\x09\x0a\x09aBoolean ifFalse: [ ^ aMessage sendTo: anObject ].\x0a\x09anObject class superclass ifNil: [ ^ self messageNotUnderstood: aMessage receiver: anObject ].\x0a\x09\x0a\x09method := anObject class superclass methodDictionary\x0a\x09\x09at: aMessage selector\x0a\x09\x09ifAbsent: [ ^ self messageNotUnderstood: aMessage receiver: anObject ].\x0a\x09\x09\x0a\x09^ method fn applyTo: anObject arguments: aMessage arguments", messageSends: ["ifFalse:", "sendTo:", "ifNil:", "messageNotUnderstood:receiver:", "superclass", "class", "at:ifAbsent:", "selector", "methodDictionary", "applyTo:arguments:", "arguments", "fn"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "shouldReturn", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@shouldReturn"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=false; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"shouldReturn",{},smalltalk.ASTInterpreter)})}, args: [], source: "shouldReturn\x0a\x09^ shouldReturn ifNil: [ false ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.ASTInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "withBlockContext:", category: 'private', fn: function (aBlock){ var self=this; var blockResult; function $AIContext(){return smalltalk.AIContext||(typeof AIContext=="undefined"?nil:AIContext)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st($AIContext())._new(); _st($1)._outerContext_(self._context()); $2=_st($1)._yourself(); self._context_($2); blockResult=_st(aBlock)._value(); self._context_(_st(self._context())._outerContext()); $3=blockResult; return $3; }, function($ctx1) {$ctx1.fill(self,"withBlockContext:",{aBlock:aBlock,blockResult:blockResult},smalltalk.ASTInterpreter)})}, args: ["aBlock"], source: "withBlockContext: aBlock\x0a\x09\x22Evaluate aBlock with a BlockContext:\x0a\x09- a context is pushed before aBlock evaluation.\x0a\x09- the context is poped after aBlock evaluation\x0a\x09- the result of aBlock evaluation is answered\x22\x0a\x09\x0a\x09| blockResult |\x0a\x09\x09\x09\x0a\x09self context: (AIContext new\x0a\x09\x09outerContext: self context;\x0a\x09\x09yourself).\x0a\x09\x0a\x09blockResult := aBlock value.\x0a\x09\x0a\x09self context: self context outerContext.\x0a\x09^ blockResult", messageSends: ["context:", "outerContext:", "context", "new", "yourself", "value", "outerContext"], referencedClasses: ["AIContext"] }), smalltalk.ASTInterpreter); smalltalk.addClass('ASTSteppingInterpreter', smalltalk.ASTInterpreter, ['continuation', 'nextNode'], 'Compiler-Interpreter'); smalltalk.ASTSteppingInterpreter.comment="I am an interpreter with stepping capabilities. The higher level `ASTDebugger` class should be used as a debugger model, as it provides convenience methods for debugging.\x0a\x0a## API\x0a\x0aUse `#step` to actually interpret the next node. Interpretation stops at each node evaluation, weither it's a message node or not.\x0a\x0a\x0a## Usage example:\x0a\x0a\x09| ast interpreter |\x0a\x09ast := Smalltalk current parse: 'foo 1+2+4'.\x0a\x09(SemanticAnalyzer on: Object) visit: ast.\x0a\x0a\x09interpreter := ASTSteppingInterpreter new\x0a\x09\x09interpret: ast nodes first;\x0a\x09\x09yourself.\x0a\x09\x09\x0a\x09interpreter step; step.\x0a\x09interpreter step; step.\x0a\x09interpreter result.\x22Answers 1\x22\x0a\x09interpreter step.\x0a\x09interpreter result. \x22Answers 3\x22\x0a\x09interpreter step.\x0a\x09interpreter result. \x22Answers 7\x22"; smalltalk.addMethod( smalltalk.method({ selector: "atEnd", category: 'testing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._shouldReturn())._or_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self._nextNode()).__eq_eq(self._currentNode()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"atEnd",{},smalltalk.ASTSteppingInterpreter)})}, args: [], source: "atEnd\x0a\x09^ self shouldReturn or: [ self nextNode == self currentNode ]", messageSends: ["or:", "==", "currentNode", "nextNode", "shouldReturn"], referencedClasses: [] }), smalltalk.ASTSteppingInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.ASTSteppingInterpreter.superclass.fn.prototype._initialize.apply(_st(self), []); self["@continuation"]=(function(){ return smalltalk.withContext(function($ctx2) { }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.ASTSteppingInterpreter)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09continuation := []", messageSends: ["initialize"], referencedClasses: [] }), smalltalk.ASTSteppingInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "interpret:continue:", category: 'interpreting', fn: function (aNode,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { self["@nextNode"]=aNode; self["@continuation"]=(function(){ return smalltalk.withContext(function($ctx2) { return smalltalk.ASTSteppingInterpreter.superclass.fn.prototype._interpret_continue_.apply(_st(self), [aNode,aBlock]); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}); return self}, function($ctx1) {$ctx1.fill(self,"interpret:continue:",{aNode:aNode,aBlock:aBlock},smalltalk.ASTSteppingInterpreter)})}, args: ["aNode", "aBlock"], source: "interpret: aNode continue: aBlock\x0a\x09nextNode := aNode.\x0a\x09continuation := [\x0a\x09\x09super interpret: aNode continue: aBlock ]", messageSends: ["interpret:continue:"], referencedClasses: [] }), smalltalk.ASTSteppingInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "nextNode", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@nextNode"]; return $1; }, function($ctx1) {$ctx1.fill(self,"nextNode",{},smalltalk.ASTSteppingInterpreter)})}, args: [], source: "nextNode\x0a\x09^ nextNode", messageSends: [], referencedClasses: [] }), smalltalk.ASTSteppingInterpreter); smalltalk.addMethod( smalltalk.method({ selector: "step", category: 'stepping', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@continuation"])._value(); return self}, function($ctx1) {$ctx1.fill(self,"step",{},smalltalk.ASTSteppingInterpreter)})}, args: [], source: "step\x0a\x09continuation value", messageSends: ["value"], referencedClasses: [] }), smalltalk.ASTSteppingInterpreter); smalltalk.addClass('ASTPCNodeVisitor', smalltalk.NodeVisitor, ['useInlinings', 'pc', 'context', 'currentNode'], 'Compiler-Interpreter'); smalltalk.ASTPCNodeVisitor.comment="I visit an AST until I get to the current pc node and answer it.\x0a\x0a## API\x0a\x0aMy instances must be filled with a context object using `#context:`.\x0a\x0aAfter visiting the AST the current node corresponding to the `pc` is answered by `#currentNode`"; smalltalk.addMethod( smalltalk.method({ selector: "context", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@context"]; return $1; }, function($ctx1) {$ctx1.fill(self,"context",{},smalltalk.ASTPCNodeVisitor)})}, args: [], source: "context\x0a\x09^ context", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "context:", category: 'accessing', fn: function (aContext){ var self=this; return smalltalk.withContext(function($ctx1) { self["@context"]=aContext; return self}, function($ctx1) {$ctx1.fill(self,"context:",{aContext:aContext},smalltalk.ASTPCNodeVisitor)})}, args: ["aContext"], source: "context: aContext\x0a\x09context := aContext", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "currentNode", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@currentNode"]; return $1; }, function($ctx1) {$ctx1.fill(self,"currentNode",{},smalltalk.ASTPCNodeVisitor)})}, args: [], source: "currentNode\x0a\x09^ currentNode", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "pc", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@pc"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=(0); } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"pc",{},smalltalk.ASTPCNodeVisitor)})}, args: [], source: "pc\x0a\x09^ pc ifNil: [ 0 ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "pc:", category: 'accessing', fn: function (anInteger){ var self=this; return smalltalk.withContext(function($ctx1) { self["@pc"]=anInteger; return self}, function($ctx1) {$ctx1.fill(self,"pc:",{anInteger:anInteger},smalltalk.ASTPCNodeVisitor)})}, args: ["anInteger"], source: "pc: anInteger\x0a\x09pc := anInteger", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "useInlinings", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@useInlinings"]; if(($receiver = $2) == nil || $receiver == undefined){ $1=true; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"useInlinings",{},smalltalk.ASTPCNodeVisitor)})}, args: [], source: "useInlinings\x0a\x09^ useInlinings ifNil: [ true ]", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "useInlinings:", category: 'accessing', fn: function (aBoolean){ var self=this; return smalltalk.withContext(function($ctx1) { self["@useInlinings"]=aBoolean; return self}, function($ctx1) {$ctx1.fill(self,"useInlinings:",{aBoolean:aBoolean},smalltalk.ASTPCNodeVisitor)})}, args: ["aBoolean"], source: "useInlinings: aBoolean\x0a\x09useInlinings := aBoolean", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitJSStatementNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { self["@currentNode"]=aNode; return self}, function($ctx1) {$ctx1.fill(self,"visitJSStatementNode:",{aNode:aNode},smalltalk.ASTPCNodeVisitor)})}, args: ["aNode"], source: "visitJSStatementNode: aNode\x0a\x09currentNode := aNode", messageSends: [], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "visitSendNode:", category: 'visiting', fn: function (aNode){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; smalltalk.ASTPCNodeVisitor.superclass.fn.prototype._visitSendNode_.apply(_st(self), [aNode]); $1=_st(self._pc()).__eq(_st(self._context())._pc()); if(! smalltalk.assert($1)){ $2=_st(aNode)._shouldBeInlined(); if(! smalltalk.assert($2)){ self._pc_(_st(self._pc()).__plus((1))); self["@currentNode"]=aNode; self["@currentNode"]; }; }; return self}, function($ctx1) {$ctx1.fill(self,"visitSendNode:",{aNode:aNode},smalltalk.ASTPCNodeVisitor)})}, args: ["aNode"], source: "visitSendNode: aNode\x0a\x09super visitSendNode: aNode.\x0a\x09\x0a\x09self pc = self context pc ifFalse: [\x0a\x09\x09aNode shouldBeInlined ifFalse: [ \x0a\x09\x09\x09self pc: self pc + 1.\x0a\x09\x09\x09currentNode := aNode ] ]", messageSends: ["visitSendNode:", "ifFalse:", "pc:", "+", "pc", "shouldBeInlined", "=", "context"], referencedClasses: [] }), smalltalk.ASTPCNodeVisitor); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.Node)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretNode: self continue: aBlock", messageSends: ["interpretNode:continue:"], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return false; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.Node)})}, args: [], source: "isSteppingNode\x0a\x09^ false", messageSends: [], referencedClasses: [] }), smalltalk.Node); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretAssignmentNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.AssignmentNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretAssignmentNode: self continue: aBlock", messageSends: ["interpretAssignmentNode:continue:"], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.AssignmentNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.AssignmentNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretBlockNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.BlockNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretBlockNode: self continue: aBlock", messageSends: ["interpretBlockNode:continue:"], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.BlockNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.BlockNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretCascadeNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.CascadeNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretCascadeNode: self continue: aBlock", messageSends: ["interpretCascadeNode:continue:"], referencedClasses: [] }), smalltalk.CascadeNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretDynamicArrayNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.DynamicArrayNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretDynamicArrayNode: self continue: aBlock", messageSends: ["interpretDynamicArrayNode:continue:"], referencedClasses: [] }), smalltalk.DynamicArrayNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.DynamicArrayNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.DynamicArrayNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretDynamicDictionaryNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.DynamicDictionaryNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretDynamicDictionaryNode: self continue: aBlock", messageSends: ["interpretDynamicDictionaryNode:continue:"], referencedClasses: [] }), smalltalk.DynamicDictionaryNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.DynamicDictionaryNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.DynamicDictionaryNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretJSStatementNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.JSStatementNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretJSStatementNode: self continue: aBlock", messageSends: ["interpretJSStatementNode:continue:"], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.JSStatementNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.JSStatementNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretMethodNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.MethodNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretMethodNode: self continue: aBlock", messageSends: ["interpretMethodNode:continue:"], referencedClasses: [] }), smalltalk.MethodNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretReturnNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.ReturnNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretReturnNode: self continue: aBlock", messageSends: ["interpretReturnNode:continue:"], referencedClasses: [] }), smalltalk.ReturnNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretSendNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.SendNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretSendNode: self continue: aBlock", messageSends: ["interpretSendNode:continue:"], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "isSteppingNode", category: '*Compiler-Interpreter', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return true; }, function($ctx1) {$ctx1.fill(self,"isSteppingNode",{},smalltalk.SendNode)})}, args: [], source: "isSteppingNode\x0a\x09^ true", messageSends: [], referencedClasses: [] }), smalltalk.SendNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretSequenceNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.SequenceNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretSequenceNode: self continue: aBlock", messageSends: ["interpretSequenceNode:continue:"], referencedClasses: [] }), smalltalk.SequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretBlockSequenceNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.BlockSequenceNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretBlockSequenceNode: self continue: aBlock", messageSends: ["interpretBlockSequenceNode:continue:"], referencedClasses: [] }), smalltalk.BlockSequenceNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretValueNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.ValueNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretValueNode: self continue: aBlock", messageSends: ["interpretValueNode:continue:"], referencedClasses: [] }), smalltalk.ValueNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretVariableNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.VariableNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretVariableNode: self continue: aBlock", messageSends: ["interpretVariableNode:continue:"], referencedClasses: [] }), smalltalk.VariableNode); smalltalk.addMethod( smalltalk.method({ selector: "interpreter:continue:", category: '*Compiler-Interpreter', fn: function (anInterpreter,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(anInterpreter)._interpretClassReferenceNode_continue_(self,aBlock); return $1; }, function($ctx1) {$ctx1.fill(self,"interpreter:continue:",{anInterpreter:anInterpreter,aBlock:aBlock},smalltalk.ClassReferenceNode)})}, args: ["anInterpreter", "aBlock"], source: "interpreter: anInterpreter continue: aBlock\x0a\x09^ anInterpreter interpretClassReferenceNode: self continue: aBlock", messageSends: ["interpretClassReferenceNode:continue:"], referencedClasses: [] }), smalltalk.ClassReferenceNode); }); define("amber_vm/parser", ["./smalltalk","./nil"],function(smalltalk,nil){ smalltalk.parser = (function(){ /* * Generated by PEG.js 0.7.0. * * http://pegjs.majda.cz/ */ function quote(s) { /* * ECMA-262, 5th ed., 7.8.4: All characters may appear literally in a * string literal except for the closing quote character, backslash, * carriage return, line separator, paragraph separator, and line feed. * Any character may appear in the form of an escape sequence. * * For portability, we also escape escape all control and non-ASCII * characters. Note that "\0" and "\v" escape sequences are not used * because JSHint does not like the first and IE the second. */ return '"' + s .replace(/\\/g, '\\\\') // backslash .replace(/"/g, '\\"') // closing quote character .replace(/\x08/g, '\\b') // backspace .replace(/\t/g, '\\t') // horizontal tab .replace(/\n/g, '\\n') // line feed .replace(/\f/g, '\\f') // form feed .replace(/\r/g, '\\r') // carriage return .replace(/[\x00-\x07\x0B\x0E-\x1F\x80-\uFFFF]/g, escape) + '"'; } var result = { /* * Parses the input with a generated parser. If the parsing is successfull, * returns a value explicitly or implicitly specified by the grammar from * which the parser was generated (see |PEG.buildParser|). If the parsing is * unsuccessful, throws |PEG.parser.SyntaxError| describing the error. */ parse: function(input, startRule) { var parseFunctions = { "separator": parse_separator, "comments": parse_comments, "ws": parse_ws, "identifier": parse_identifier, "varIdentifier": parse_varIdentifier, "keyword": parse_keyword, "selector": parse_selector, "className": parse_className, "string": parse_string, "symbol": parse_symbol, "bareSymbol": parse_bareSymbol, "number": parse_number, "hex": parse_hex, "float": parse_float, "integer": parse_integer, "literalArray": parse_literalArray, "bareLiteralArray": parse_bareLiteralArray, "literalArrayRest": parse_literalArrayRest, "dynamicArray": parse_dynamicArray, "dynamicDictionary": parse_dynamicDictionary, "pseudoVariable": parse_pseudoVariable, "parseTimeLiteral": parse_parseTimeLiteral, "runtimeLiteral": parse_runtimeLiteral, "literal": parse_literal, "variable": parse_variable, "classReference": parse_classReference, "reference": parse_reference, "keywordPair": parse_keywordPair, "binarySelector": parse_binarySelector, "keywordPattern": parse_keywordPattern, "binaryPattern": parse_binaryPattern, "unaryPattern": parse_unaryPattern, "expression": parse_expression, "expressionList": parse_expressionList, "expressions": parse_expressions, "assignment": parse_assignment, "ret": parse_ret, "temps": parse_temps, "blockParamList": parse_blockParamList, "subexpression": parse_subexpression, "statements": parse_statements, "sequence": parse_sequence, "stSequence": parse_stSequence, "block": parse_block, "operand": parse_operand, "unaryMessage": parse_unaryMessage, "unaryTail": parse_unaryTail, "unarySend": parse_unarySend, "binaryMessage": parse_binaryMessage, "binaryTail": parse_binaryTail, "binarySend": parse_binarySend, "keywordMessage": parse_keywordMessage, "keywordSend": parse_keywordSend, "message": parse_message, "cascade": parse_cascade, "jsStatement": parse_jsStatement, "method": parse_method }; if (startRule !== undefined) { if (parseFunctions[startRule] === undefined) { throw new Error("Invalid rule name: " + quote(startRule) + "."); } } else { startRule = "method"; } var pos = { offset: 0, line: 1, column: 1, seenCR: false }; var reportFailures = 0; var rightmostFailuresPos = { offset: 0, line: 1, column: 1, seenCR: false }; var rightmostFailuresExpected = []; var cache = {}; function padLeft(input, padding, length) { var result = input; var padLength = length - input.length; for (var i = 0; i < padLength; i++) { result = padding + result; } return result; } function escape(ch) { var charCode = ch.charCodeAt(0); var escapeChar; var length; if (charCode <= 0xFF) { escapeChar = 'x'; length = 2; } else { escapeChar = 'u'; length = 4; } return '\\' + escapeChar + padLeft(charCode.toString(16).toUpperCase(), '0', length); } function clone(object) { var result = {}; for (var key in object) { result[key] = object[key]; } return result; } function advance(pos, n) { var endOffset = pos.offset + n; for (var offset = pos.offset; offset < endOffset; offset++) { var ch = input.charAt(offset); if (ch === "\n") { if (!pos.seenCR) { pos.line++; } pos.column = 1; pos.seenCR = false; } else if (ch === "\r" || ch === "\u2028" || ch === "\u2029") { pos.line++; pos.column = 1; pos.seenCR = true; } else { pos.column++; pos.seenCR = false; } } pos.offset += n; } function matchFailed(failure) { if (pos.offset < rightmostFailuresPos.offset) { return; } if (pos.offset > rightmostFailuresPos.offset) { rightmostFailuresPos = clone(pos); rightmostFailuresExpected = []; } rightmostFailuresExpected.push(failure); } function parse_separator() { var cacheKey = "separator@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; if (/^[ \t\x0B\f\xA0\uFEFF\n\r\u2028\u2029]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[ \\t\\x0B\\f\\xA0\\uFEFF\\n\\r\\u2028\\u2029]"); } } if (result1 !== null) { result0 = []; while (result1 !== null) { result0.push(result1); if (/^[ \t\x0B\f\xA0\uFEFF\n\r\u2028\u2029]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[ \\t\\x0B\\f\\xA0\\uFEFF\\n\\r\\u2028\\u2029]"); } } } } else { result0 = null; } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_comments() { var cacheKey = "comments@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0; pos0 = clone(pos); if (/^["]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[\"]"); } } if (result1 !== null) { result2 = []; if (/^[^"]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[^\"]"); } } while (result3 !== null) { result2.push(result3); if (/^[^"]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[^\"]"); } } } if (result2 !== null) { if (/^["]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[\"]"); } } if (result3 !== null) { result1 = [result1, result2, result3]; } else { result1 = null; pos = clone(pos0); } } else { result1 = null; pos = clone(pos0); } } else { result1 = null; pos = clone(pos0); } if (result1 !== null) { result0 = []; while (result1 !== null) { result0.push(result1); pos0 = clone(pos); if (/^["]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[\"]"); } } if (result1 !== null) { result2 = []; if (/^[^"]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[^\"]"); } } while (result3 !== null) { result2.push(result3); if (/^[^"]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[^\"]"); } } } if (result2 !== null) { if (/^["]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[\"]"); } } if (result3 !== null) { result1 = [result1, result2, result3]; } else { result1 = null; pos = clone(pos0); } } else { result1 = null; pos = clone(pos0); } } else { result1 = null; pos = clone(pos0); } } } else { result0 = null; } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_ws() { var cacheKey = "ws@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; result0 = []; result1 = parse_separator(); if (result1 === null) { result1 = parse_comments(); } while (result1 !== null) { result0.push(result1); result1 = parse_separator(); if (result1 === null) { result1 = parse_comments(); } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_identifier() { var cacheKey = "identifier@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[a-zA-Z]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z]"); } } if (result0 !== null) { result1 = []; if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } while (result2 !== null) { result1.push(result2); if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, others) {return first + others.join("");})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_varIdentifier() { var cacheKey = "varIdentifier@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[a-z]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[a-z]"); } } if (result0 !== null) { result1 = []; if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } while (result2 !== null) { result1.push(result2); if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, others) {return first + others.join("");})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_keyword() { var cacheKey = "keyword@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_identifier(); if (result0 !== null) { if (/^[:]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[:]"); } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, last) {return first + last;})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_selector() { var cacheKey = "selector@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[a-zA-Z]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z]"); } } if (result0 !== null) { result1 = []; if (/^[a-zA-Z0-9:]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9:]"); } } while (result2 !== null) { result1.push(result2); if (/^[a-zA-Z0-9:]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9:]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, others) {return first + others.join("");})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_className() { var cacheKey = "className@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[A-Z]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[A-Z]"); } } if (result0 !== null) { result1 = []; if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } while (result2 !== null) { result1.push(result2); if (/^[a-zA-Z0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[a-zA-Z0-9]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, others) {return first + others.join("");})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_string() { var cacheKey = "string@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1, pos2; pos0 = clone(pos); pos1 = clone(pos); if (/^[']/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[']"); } } if (result0 !== null) { result1 = []; pos2 = clone(pos); if (input.substr(pos.offset, 2) === "''") { result2 = "''"; advance(pos, 2); } else { result2 = null; if (reportFailures === 0) { matchFailed("\"''\""); } } if (result2 !== null) { result2 = (function(offset, line, column) {return "'";})(pos2.offset, pos2.line, pos2.column); } if (result2 === null) { pos = clone(pos2); } if (result2 === null) { if (/^[^']/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[^']"); } } } while (result2 !== null) { result1.push(result2); pos2 = clone(pos); if (input.substr(pos.offset, 2) === "''") { result2 = "''"; advance(pos, 2); } else { result2 = null; if (reportFailures === 0) { matchFailed("\"''\""); } } if (result2 !== null) { result2 = (function(offset, line, column) {return "'";})(pos2.offset, pos2.line, pos2.column); } if (result2 === null) { pos = clone(pos2); } if (result2 === null) { if (/^[^']/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[^']"); } } } } if (result1 !== null) { if (/^[']/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[']"); } } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, val) { return smalltalk.ValueNode._new() ._position_((line).__at(column)) ._value_(val.join("").replace(/\"/ig, '"')); })(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_symbol() { var cacheKey = "symbol@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 35) { result0 = "#"; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"#\""); } } if (result0 !== null) { result1 = parse_bareSymbol(); if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, rest) {return rest;})(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_bareSymbol() { var cacheKey = "bareSymbol@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; var pos0, pos1; pos0 = clone(pos); result0 = parse_selector(); if (result0 === null) { result0 = parse_binarySelector(); if (result0 === null) { pos1 = clone(pos); result0 = parse_string(); if (result0 !== null) { result0 = (function(offset, line, column, node) {return node._value();})(pos1.offset, pos1.line, pos1.column, result0); } if (result0 === null) { pos = clone(pos1); } } } if (result0 !== null) { result0 = (function(offset, line, column, val) { return smalltalk.ValueNode._new() ._position_((line).__at(column)) ._value_(val); })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_number() { var cacheKey = "number@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; var pos0; pos0 = clone(pos); result0 = parse_hex(); if (result0 === null) { result0 = parse_float(); if (result0 === null) { result0 = parse_integer(); } } if (result0 !== null) { result0 = (function(offset, line, column, n) { return smalltalk.ValueNode._new() ._position_((line).__at(column)) ._value_(n); })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_hex() { var cacheKey = "hex@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[\-]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[\\-]"); } } result0 = result0 !== null ? result0 : ""; if (result0 !== null) { if (input.substr(pos.offset, 3) === "16r") { result1 = "16r"; advance(pos, 3); } else { result1 = null; if (reportFailures === 0) { matchFailed("\"16r\""); } } if (result1 !== null) { if (/^[0-9a-fA-F]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[0-9a-fA-F]"); } } if (result3 !== null) { result2 = []; while (result3 !== null) { result2.push(result3); if (/^[0-9a-fA-F]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[0-9a-fA-F]"); } } } } else { result2 = null; } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, neg, num) {return parseInt((neg + num.join("")), 16);})(pos0.offset, pos0.line, pos0.column, result0[0], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_float() { var cacheKey = "float@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[\-]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[\\-]"); } } result0 = result0 !== null ? result0 : ""; if (result0 !== null) { if (/^[0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } if (result2 !== null) { result1 = []; while (result2 !== null) { result1.push(result2); if (/^[0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } } } else { result1 = null; } if (result1 !== null) { if (input.charCodeAt(pos.offset) === 46) { result2 = "."; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\".\""); } } if (result2 !== null) { if (/^[0-9]/.test(input.charAt(pos.offset))) { result4 = input.charAt(pos.offset); advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } if (result4 !== null) { result3 = []; while (result4 !== null) { result3.push(result4); if (/^[0-9]/.test(input.charAt(pos.offset))) { result4 = input.charAt(pos.offset); advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } } } else { result3 = null; } if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, neg, digits, dec) {return parseFloat((neg + digits.join("") + "." + dec.join("")), 10);})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1], result0[3]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_integer() { var cacheKey = "integer@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (/^[\-]/.test(input.charAt(pos.offset))) { result0 = input.charAt(pos.offset); advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("[\\-]"); } } result0 = result0 !== null ? result0 : ""; if (result0 !== null) { if (/^[0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } if (result2 !== null) { result1 = []; while (result2 !== null) { result1.push(result2); if (/^[0-9]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[0-9]"); } } } } else { result1 = null; } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, neg, digits) {return (parseInt(neg+digits.join(""), 10));})(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_literalArray() { var cacheKey = "literalArray@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.substr(pos.offset, 2) === "#(") { result0 = "#("; advance(pos, 2); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"#(\""); } } if (result0 !== null) { result1 = parse_literalArrayRest(); if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, rest) {return rest;})(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_bareLiteralArray() { var cacheKey = "bareLiteralArray@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 40) { result0 = "("; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"(\""); } } if (result0 !== null) { result1 = parse_literalArrayRest(); if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, rest) {return rest;})(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_literalArrayRest() { var cacheKey = "literalArrayRest@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1, pos2, pos3; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = []; pos2 = clone(pos); pos3 = clone(pos); result2 = parse_parseTimeLiteral(); if (result2 === null) { result2 = parse_bareLiteralArray(); if (result2 === null) { result2 = parse_bareSymbol(); } } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result2 = [result2, result3]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, lit) {return lit._value();})(pos2.offset, pos2.line, pos2.column, result2[0]); } if (result2 === null) { pos = clone(pos2); } while (result2 !== null) { result1.push(result2); pos2 = clone(pos); pos3 = clone(pos); result2 = parse_parseTimeLiteral(); if (result2 === null) { result2 = parse_bareLiteralArray(); if (result2 === null) { result2 = parse_bareSymbol(); } } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result2 = [result2, result3]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, lit) {return lit._value();})(pos2.offset, pos2.line, pos2.column, result2[0]); } if (result2 === null) { pos = clone(pos2); } } if (result1 !== null) { result2 = parse_ws(); if (result2 !== null) { if (input.charCodeAt(pos.offset) === 41) { result3 = ")"; advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("\")\""); } } if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, lits) { return smalltalk.ValueNode._new() ._position_((line).__at(column)) ._value_(lits); })(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_dynamicArray() { var cacheKey = "dynamicArray@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4, result5; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 123) { result0 = "{"; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"{\""); } } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_expressions(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 46) { result4 = "."; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\".\""); } } result4 = result4 !== null ? result4 : ""; if (result4 !== null) { if (input.charCodeAt(pos.offset) === 125) { result5 = "}"; advance(pos, 1); } else { result5 = null; if (reportFailures === 0) { matchFailed("\"}\""); } } if (result5 !== null) { result0 = [result0, result1, result2, result3, result4, result5]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expressions) { return smalltalk.DynamicArrayNode._new() ._position_((line).__at(column)) ._nodes_(expressions); })(pos0.offset, pos0.line, pos0.column, result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_dynamicDictionary() { var cacheKey = "dynamicDictionary@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.substr(pos.offset, 2) === "#{") { result0 = "#{"; advance(pos, 2); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"#{\""); } } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_expressions(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 125) { result4 = "}"; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\"}\""); } } if (result4 !== null) { result0 = [result0, result1, result2, result3, result4]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expressions) { return smalltalk.DynamicDictionaryNode._new() ._position_((line).__at(column)) ._nodes_(expressions); })(pos0.offset, pos0.line, pos0.column, result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_pseudoVariable() { var cacheKey = "pseudoVariable@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.substr(pos.offset, 4) === "true") { result0 = "true"; advance(pos, 4); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"true\""); } } if (result0 !== null) { result0 = (function(offset, line, column) {return true;})(pos1.offset, pos1.line, pos1.column); } if (result0 === null) { pos = clone(pos1); } if (result0 === null) { pos1 = clone(pos); if (input.substr(pos.offset, 5) === "false") { result0 = "false"; advance(pos, 5); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"false\""); } } if (result0 !== null) { result0 = (function(offset, line, column) {return false;})(pos1.offset, pos1.line, pos1.column); } if (result0 === null) { pos = clone(pos1); } if (result0 === null) { pos1 = clone(pos); if (input.substr(pos.offset, 3) === "nil") { result0 = "nil"; advance(pos, 3); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"nil\""); } } if (result0 !== null) { result0 = (function(offset, line, column) {return nil;})(pos1.offset, pos1.line, pos1.column); } if (result0 === null) { pos = clone(pos1); } } } if (result0 !== null) { result0 = (function(offset, line, column, val) { return smalltalk.ValueNode._new() ._position_((line).__at(column)) ._value_(val); })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_parseTimeLiteral() { var cacheKey = "parseTimeLiteral@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_pseudoVariable(); if (result0 === null) { result0 = parse_number(); if (result0 === null) { result0 = parse_literalArray(); if (result0 === null) { result0 = parse_string(); if (result0 === null) { result0 = parse_symbol(); } } } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_runtimeLiteral() { var cacheKey = "runtimeLiteral@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_dynamicDictionary(); if (result0 === null) { result0 = parse_dynamicArray(); if (result0 === null) { result0 = parse_block(); } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_literal() { var cacheKey = "literal@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_runtimeLiteral(); if (result0 === null) { result0 = parse_parseTimeLiteral(); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_variable() { var cacheKey = "variable@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; var pos0; pos0 = clone(pos); result0 = parse_varIdentifier(); if (result0 !== null) { result0 = (function(offset, line, column, identifier) { return smalltalk.VariableNode._new() ._position_((line).__at(column)) ._value_(identifier); })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_classReference() { var cacheKey = "classReference@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; var pos0; pos0 = clone(pos); result0 = parse_className(); if (result0 !== null) { result0 = (function(offset, line, column, className) { return smalltalk.ClassReferenceNode._new() ._position_((line).__at(column)) ._value_(className); })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_reference() { var cacheKey = "reference@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_variable(); if (result0 === null) { result0 = parse_classReference(); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_keywordPair() { var cacheKey = "keywordPair@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_keyword(); if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_binarySend(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, key, arg) {return {key:key, arg: arg};})(pos0.offset, pos0.line, pos0.column, result0[0], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_binarySelector() { var cacheKey = "binarySelector@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0; pos0 = clone(pos); if (/^[\\+*\/=><,@%~|&\-]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[\\\\+*\\/=><,@%~|&\\-]"); } } if (result1 !== null) { result0 = []; while (result1 !== null) { result0.push(result1); if (/^[\\+*\/=><,@%~|&\-]/.test(input.charAt(pos.offset))) { result1 = input.charAt(pos.offset); advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("[\\\\+*\\/=><,@%~|&\\-]"); } } } } else { result0 = null; } if (result0 !== null) { result0 = (function(offset, line, column, bin) {return bin.join("");})(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_keywordPattern() { var cacheKey = "keywordPattern@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1, pos2; pos0 = clone(pos); pos1 = clone(pos); pos2 = clone(pos); result1 = parse_ws(); if (result1 !== null) { result2 = parse_keyword(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_identifier(); if (result4 !== null) { result1 = [result1, result2, result3, result4]; } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } if (result1 !== null) { result1 = (function(offset, line, column, key, arg) {return {key:key, arg: arg};})(pos1.offset, pos1.line, pos1.column, result1[1], result1[3]); } if (result1 === null) { pos = clone(pos1); } if (result1 !== null) { result0 = []; while (result1 !== null) { result0.push(result1); pos1 = clone(pos); pos2 = clone(pos); result1 = parse_ws(); if (result1 !== null) { result2 = parse_keyword(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_identifier(); if (result4 !== null) { result1 = [result1, result2, result3, result4]; } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } } else { result1 = null; pos = clone(pos2); } if (result1 !== null) { result1 = (function(offset, line, column, key, arg) {return {key:key, arg: arg};})(pos1.offset, pos1.line, pos1.column, result1[1], result1[3]); } if (result1 === null) { pos = clone(pos1); } } } else { result0 = null; } if (result0 !== null) { result0 = (function(offset, line, column, pairs) { var keywords = []; var params = []; var i = 0; for(i = 0; i < pairs.length; i++){ keywords.push(pairs[i].key); } for(i = 0; i < pairs.length; i++){ params.push(pairs[i].arg); } return [keywords.join(""), params]; })(pos0.offset, pos0.line, pos0.column, result0); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_binaryPattern() { var cacheKey = "binaryPattern@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_binarySelector(); if (result1 !== null) { result2 = parse_ws(); if (result2 !== null) { result3 = parse_identifier(); if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, selector, arg) {return [selector, [arg]];})(pos0.offset, pos0.line, pos0.column, result0[1], result0[3]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_unaryPattern() { var cacheKey = "unaryPattern@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_identifier(); if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, selector) {return [selector, []];})(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_expression() { var cacheKey = "expression@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_assignment(); if (result0 === null) { result0 = parse_cascade(); if (result0 === null) { result0 = parse_keywordSend(); if (result0 === null) { result0 = parse_binarySend(); } } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_expressionList() { var cacheKey = "expressionList@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { if (input.charCodeAt(pos.offset) === 46) { result1 = "."; advance(pos, 1); } else { result1 = null; if (reportFailures === 0) { matchFailed("\".\""); } } if (result1 !== null) { result2 = parse_ws(); if (result2 !== null) { result3 = parse_expression(); if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expression) {return expression;})(pos0.offset, pos0.line, pos0.column, result0[3]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_expressions() { var cacheKey = "expressions@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_expression(); if (result0 !== null) { result1 = []; result2 = parse_expressionList(); while (result2 !== null) { result1.push(result2); result2 = parse_expressionList(); } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, first, others) { var result = [first]; for(var i = 0; i < others.length; i++) { result.push(others[i]); } return result; })(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_assignment() { var cacheKey = "assignment@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_variable(); if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { if (input.substr(pos.offset, 2) === ":=") { result2 = ":="; advance(pos, 2); } else { result2 = null; if (reportFailures === 0) { matchFailed("\":=\""); } } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_expression(); if (result4 !== null) { result0 = [result0, result1, result2, result3, result4]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, variable, expression) { return smalltalk.AssignmentNode._new() ._position_((line).__at(column)) ._left_(variable) ._right_(expression); })(pos0.offset, pos0.line, pos0.column, result0[0], result0[4]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_ret() { var cacheKey = "ret@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 94) { result0 = "^"; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"^\""); } } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_expression(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 46) { result4 = "."; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\".\""); } } result4 = result4 !== null ? result4 : ""; if (result4 !== null) { result0 = [result0, result1, result2, result3, result4]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expression) { return smalltalk.ReturnNode._new() ._position_((line).__at(column)) ._nodes_([expression]); })(pos0.offset, pos0.line, pos0.column, result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_temps() { var cacheKey = "temps@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1, pos2, pos3; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 124) { result0 = "|"; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"|\""); } } if (result0 !== null) { result1 = []; pos2 = clone(pos); pos3 = clone(pos); result2 = parse_ws(); if (result2 !== null) { result3 = parse_identifier(); if (result3 !== null) { result4 = parse_ws(); if (result4 !== null) { result2 = [result2, result3, result4]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, variable) {return variable;})(pos2.offset, pos2.line, pos2.column, result2[1]); } if (result2 === null) { pos = clone(pos2); } while (result2 !== null) { result1.push(result2); pos2 = clone(pos); pos3 = clone(pos); result2 = parse_ws(); if (result2 !== null) { result3 = parse_identifier(); if (result3 !== null) { result4 = parse_ws(); if (result4 !== null) { result2 = [result2, result3, result4]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, variable) {return variable;})(pos2.offset, pos2.line, pos2.column, result2[1]); } if (result2 === null) { pos = clone(pos2); } } if (result1 !== null) { if (input.charCodeAt(pos.offset) === 124) { result2 = "|"; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\"|\""); } } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, vars) {return vars;})(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_blockParamList() { var cacheKey = "blockParamList@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1, pos2, pos3; pos0 = clone(pos); pos1 = clone(pos); pos2 = clone(pos); pos3 = clone(pos); result1 = parse_ws(); if (result1 !== null) { if (input.charCodeAt(pos.offset) === 58) { result2 = ":"; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\":\""); } } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_identifier(); if (result4 !== null) { result1 = [result1, result2, result3, result4]; } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } if (result1 !== null) { result1 = (function(offset, line, column, param) {return param;})(pos2.offset, pos2.line, pos2.column, result1[3]); } if (result1 === null) { pos = clone(pos2); } if (result1 !== null) { result0 = []; while (result1 !== null) { result0.push(result1); pos2 = clone(pos); pos3 = clone(pos); result1 = parse_ws(); if (result1 !== null) { if (input.charCodeAt(pos.offset) === 58) { result2 = ":"; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\":\""); } } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_identifier(); if (result4 !== null) { result1 = [result1, result2, result3, result4]; } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } } else { result1 = null; pos = clone(pos3); } if (result1 !== null) { result1 = (function(offset, line, column, param) {return param;})(pos2.offset, pos2.line, pos2.column, result1[3]); } if (result1 === null) { pos = clone(pos2); } } } else { result0 = null; } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { if (input.charCodeAt(pos.offset) === 124) { result2 = "|"; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\"|\""); } } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, params) {return params;})(pos0.offset, pos0.line, pos0.column, result0[0]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_subexpression() { var cacheKey = "subexpression@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 40) { result0 = "("; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"(\""); } } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_expression(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 41) { result4 = ")"; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\")\""); } } if (result4 !== null) { result0 = [result0, result1, result2, result3, result4]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expression) {return expression;})(pos0.offset, pos0.line, pos0.column, result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_statements() { var cacheKey = "statements@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4, result5, result6; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ret(); if (result0 !== null) { result1 = []; if (/^[.]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[.]"); } } while (result2 !== null) { result1.push(result2); if (/^[.]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[.]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, ret) {return [ret];})(pos0.offset, pos0.line, pos0.column, result0[0]); } if (result0 === null) { pos = clone(pos0); } if (result0 === null) { pos0 = clone(pos); pos1 = clone(pos); result0 = parse_expressions(); if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { if (/^[.]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[.]"); } } if (result3 !== null) { result2 = []; while (result3 !== null) { result2.push(result3); if (/^[.]/.test(input.charAt(pos.offset))) { result3 = input.charAt(pos.offset); advance(pos, 1); } else { result3 = null; if (reportFailures === 0) { matchFailed("[.]"); } } } } else { result2 = null; } if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_ret(); if (result4 !== null) { result5 = []; if (/^[.]/.test(input.charAt(pos.offset))) { result6 = input.charAt(pos.offset); advance(pos, 1); } else { result6 = null; if (reportFailures === 0) { matchFailed("[.]"); } } while (result6 !== null) { result5.push(result6); if (/^[.]/.test(input.charAt(pos.offset))) { result6 = input.charAt(pos.offset); advance(pos, 1); } else { result6 = null; if (reportFailures === 0) { matchFailed("[.]"); } } } if (result5 !== null) { result0 = [result0, result1, result2, result3, result4, result5]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, exps, ret) { var expressions = exps; expressions.push(ret); return expressions; })(pos0.offset, pos0.line, pos0.column, result0[0], result0[4]); } if (result0 === null) { pos = clone(pos0); } if (result0 === null) { pos0 = clone(pos); pos1 = clone(pos); result0 = parse_expressions(); result0 = result0 !== null ? result0 : ""; if (result0 !== null) { result1 = []; if (/^[.]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[.]"); } } while (result2 !== null) { result1.push(result2); if (/^[.]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[.]"); } } } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, expressions) { return expressions || []; })(pos0.offset, pos0.line, pos0.column, result0[0]); } if (result0 === null) { pos = clone(pos0); } } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_sequence() { var cacheKey = "sequence@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_jsStatement(); if (result0 === null) { result0 = parse_stSequence(); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_stSequence() { var cacheKey = "stSequence@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_temps(); result0 = result0 !== null ? result0 : ""; if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_statements(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, temps, statements) { return smalltalk.SequenceNode._new() ._position_((line).__at(column)) ._temps_(temps || []) ._nodes_(statements || []); })(pos0.offset, pos0.line, pos0.column, result0[0], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_block() { var cacheKey = "block@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4, result5, result6; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 91) { result0 = "["; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"[\""); } } if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_blockParamList(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result4 = parse_sequence(); result4 = result4 !== null ? result4 : ""; if (result4 !== null) { result5 = parse_ws(); if (result5 !== null) { if (input.charCodeAt(pos.offset) === 93) { result6 = "]"; advance(pos, 1); } else { result6 = null; if (reportFailures === 0) { matchFailed("\"]\""); } } if (result6 !== null) { result0 = [result0, result1, result2, result3, result4, result5, result6]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, params, sequence) { return smalltalk.BlockNode._new() ._position_((line).__at(column)) ._parameters_(params || []) ._nodes_([sequence._asBlockSequenceNode()]); })(pos0.offset, pos0.line, pos0.column, result0[2], result0[4]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_operand() { var cacheKey = "operand@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_literal(); if (result0 === null) { result0 = parse_reference(); if (result0 === null) { result0 = parse_subexpression(); } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_unaryMessage() { var cacheKey = "unaryMessage@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1, pos2; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_identifier(); if (result1 !== null) { pos2 = clone(pos); reportFailures++; if (/^[:]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[:]"); } } reportFailures--; if (result2 === null) { result2 = ""; } else { result2 = null; pos = clone(pos2); } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, selector) { return smalltalk.SendNode._new() ._position_((line).__at(column)) ._selector_(selector); })(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_unaryTail() { var cacheKey = "unaryTail@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_unaryMessage(); if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_unaryTail(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, message, tail) { if(tail) { return tail._valueForReceiver_(message); } else { return message; } })(pos0.offset, pos0.line, pos0.column, result0[0], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_unarySend() { var cacheKey = "unarySend@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_operand(); if (result0 !== null) { result1 = parse_ws(); if (result1 !== null) { result2 = parse_unaryTail(); result2 = result2 !== null ? result2 : ""; if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, receiver, tail) { if(tail) { return tail._valueForReceiver_(receiver); } else { return receiver; } })(pos0.offset, pos0.line, pos0.column, result0[0], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_binaryMessage() { var cacheKey = "binaryMessage@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_binarySelector(); if (result1 !== null) { result2 = parse_ws(); if (result2 !== null) { result3 = parse_unarySend(); if (result3 === null) { result3 = parse_operand(); } if (result3 !== null) { result0 = [result0, result1, result2, result3]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, selector, arg) { return smalltalk.SendNode._new() ._position_((line).__at(column)) ._selector_(selector) ._arguments_([arg]); })(pos0.offset, pos0.line, pos0.column, result0[1], result0[3]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_binaryTail() { var cacheKey = "binaryTail@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_binaryMessage(); if (result0 !== null) { result1 = parse_binaryTail(); result1 = result1 !== null ? result1 : ""; if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, message, tail) { if(tail) { return tail._valueForReceiver_(message); } else { return message; } })(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_binarySend() { var cacheKey = "binarySend@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_unarySend(); if (result0 !== null) { result1 = parse_binaryTail(); result1 = result1 !== null ? result1 : ""; if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, receiver, tail) { if(tail) { return tail._valueForReceiver_(receiver); } else { return receiver; } })(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_keywordMessage() { var cacheKey = "keywordMessage@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3; var pos0, pos1, pos2, pos3; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { pos2 = clone(pos); pos3 = clone(pos); result2 = parse_keywordPair(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result2 = [result2, result3]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, pair) {return pair;})(pos2.offset, pos2.line, pos2.column, result2[0]); } if (result2 === null) { pos = clone(pos2); } if (result2 !== null) { result1 = []; while (result2 !== null) { result1.push(result2); pos2 = clone(pos); pos3 = clone(pos); result2 = parse_keywordPair(); if (result2 !== null) { result3 = parse_ws(); if (result3 !== null) { result2 = [result2, result3]; } else { result2 = null; pos = clone(pos3); } } else { result2 = null; pos = clone(pos3); } if (result2 !== null) { result2 = (function(offset, line, column, pair) {return pair;})(pos2.offset, pos2.line, pos2.column, result2[0]); } if (result2 === null) { pos = clone(pos2); } } } else { result1 = null; } if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, pairs) { var selector = []; var args = []; for(var i = 0; i < pairs.length; i++) { selector.push(pairs[i].key); args.push(pairs[i].arg); } return smalltalk.SendNode._new() ._position_((line).__at(column)) ._selector_(selector.join("")) ._arguments_(args); })(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_keywordSend() { var cacheKey = "keywordSend@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_binarySend(); if (result0 !== null) { result1 = parse_keywordMessage(); if (result1 !== null) { result0 = [result0, result1]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, receiver, tail) { return tail._valueForReceiver_(receiver); })(pos0.offset, pos0.line, pos0.column, result0[0], result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_message() { var cacheKey = "message@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0; result0 = parse_binaryMessage(); if (result0 === null) { result0 = parse_unaryMessage(); if (result0 === null) { result0 = parse_keywordMessage(); } } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_cascade() { var cacheKey = "cascade@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4, result5, result6, result7; var pos0, pos1, pos2, pos3; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_keywordSend(); if (result1 === null) { result1 = parse_binarySend(); } if (result1 !== null) { pos2 = clone(pos); pos3 = clone(pos); result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 59) { result4 = ";"; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\";\""); } } if (result4 !== null) { result5 = parse_ws(); if (result5 !== null) { result6 = parse_message(); if (result6 !== null) { result7 = parse_ws(); if (result7 !== null) { result3 = [result3, result4, result5, result6, result7]; } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } if (result3 !== null) { result3 = (function(offset, line, column, mess) {return mess;})(pos2.offset, pos2.line, pos2.column, result3[3]); } if (result3 === null) { pos = clone(pos2); } if (result3 !== null) { result2 = []; while (result3 !== null) { result2.push(result3); pos2 = clone(pos); pos3 = clone(pos); result3 = parse_ws(); if (result3 !== null) { if (input.charCodeAt(pos.offset) === 59) { result4 = ";"; advance(pos, 1); } else { result4 = null; if (reportFailures === 0) { matchFailed("\";\""); } } if (result4 !== null) { result5 = parse_ws(); if (result5 !== null) { result6 = parse_message(); if (result6 !== null) { result7 = parse_ws(); if (result7 !== null) { result3 = [result3, result4, result5, result6, result7]; } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } } else { result3 = null; pos = clone(pos3); } if (result3 !== null) { result3 = (function(offset, line, column, mess) {return mess;})(pos2.offset, pos2.line, pos2.column, result3[3]); } if (result3 === null) { pos = clone(pos2); } } } else { result2 = null; } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, send, messages) { var cascade = []; cascade.push(send); for(var i = 0; i < messages.length; i++) { cascade.push(messages[i]); } return smalltalk.CascadeNode._new() ._position_((line).__at(column)) ._receiver_(send._receiver()) ._nodes_(cascade); })(pos0.offset, pos0.line, pos0.column, result0[1], result0[2]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_jsStatement() { var cacheKey = "jsStatement@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2; var pos0, pos1, pos2; pos0 = clone(pos); pos1 = clone(pos); if (input.charCodeAt(pos.offset) === 60) { result0 = "<"; advance(pos, 1); } else { result0 = null; if (reportFailures === 0) { matchFailed("\"<\""); } } if (result0 !== null) { result1 = []; pos2 = clone(pos); if (input.substr(pos.offset, 2) === ">>") { result2 = ">>"; advance(pos, 2); } else { result2 = null; if (reportFailures === 0) { matchFailed("\">>\""); } } if (result2 !== null) { result2 = (function(offset, line, column) {return ">";})(pos2.offset, pos2.line, pos2.column); } if (result2 === null) { pos = clone(pos2); } if (result2 === null) { if (/^[^>]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[^>]"); } } } while (result2 !== null) { result1.push(result2); pos2 = clone(pos); if (input.substr(pos.offset, 2) === ">>") { result2 = ">>"; advance(pos, 2); } else { result2 = null; if (reportFailures === 0) { matchFailed("\">>\""); } } if (result2 !== null) { result2 = (function(offset, line, column) {return ">";})(pos2.offset, pos2.line, pos2.column); } if (result2 === null) { pos = clone(pos2); } if (result2 === null) { if (/^[^>]/.test(input.charAt(pos.offset))) { result2 = input.charAt(pos.offset); advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("[^>]"); } } } } if (result1 !== null) { if (input.charCodeAt(pos.offset) === 62) { result2 = ">"; advance(pos, 1); } else { result2 = null; if (reportFailures === 0) { matchFailed("\">\""); } } if (result2 !== null) { result0 = [result0, result1, result2]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, val) { return smalltalk.JSStatementNode._new() ._position_((line).__at(column)) ._source_(val.join("")); })(pos0.offset, pos0.line, pos0.column, result0[1]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function parse_method() { var cacheKey = "method@" + pos.offset; var cachedResult = cache[cacheKey]; if (cachedResult) { pos = clone(cachedResult.nextPos); return cachedResult.result; } var result0, result1, result2, result3, result4; var pos0, pos1; pos0 = clone(pos); pos1 = clone(pos); result0 = parse_ws(); if (result0 !== null) { result1 = parse_keywordPattern(); if (result1 === null) { result1 = parse_binaryPattern(); if (result1 === null) { result1 = parse_unaryPattern(); } } if (result1 !== null) { result2 = parse_ws(); if (result2 !== null) { result3 = parse_sequence(); result3 = result3 !== null ? result3 : ""; if (result3 !== null) { result4 = parse_ws(); if (result4 !== null) { result0 = [result0, result1, result2, result3, result4]; } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } } else { result0 = null; pos = clone(pos1); } if (result0 !== null) { result0 = (function(offset, line, column, pattern, sequence) { return smalltalk.MethodNode._new() ._position_((line).__at(column)) ._selector_(pattern[0]) ._arguments_(pattern[1]) ._nodes_([sequence]); })(pos0.offset, pos0.line, pos0.column, result0[1], result0[3]); } if (result0 === null) { pos = clone(pos0); } cache[cacheKey] = { nextPos: clone(pos), result: result0 }; return result0; } function cleanupExpected(expected) { expected.sort(); var lastExpected = null; var cleanExpected = []; for (var i = 0; i < expected.length; i++) { if (expected[i] !== lastExpected) { cleanExpected.push(expected[i]); lastExpected = expected[i]; } } return cleanExpected; } var result = parseFunctions[startRule](); /* * The parser is now in one of the following three states: * * 1. The parser successfully parsed the whole input. * * - |result !== null| * - |pos.offset === input.length| * - |rightmostFailuresExpected| may or may not contain something * * 2. The parser successfully parsed only a part of the input. * * - |result !== null| * - |pos.offset < input.length| * - |rightmostFailuresExpected| may or may not contain something * * 3. The parser did not successfully parse any part of the input. * * - |result === null| * - |pos.offset === 0| * - |rightmostFailuresExpected| contains at least one failure * * All code following this comment (including called functions) must * handle these states. */ if (result === null || pos.offset !== input.length) { var offset = Math.max(pos.offset, rightmostFailuresPos.offset); var found = offset < input.length ? input.charAt(offset) : null; var errorPosition = pos.offset > rightmostFailuresPos.offset ? pos : rightmostFailuresPos; throw new this.SyntaxError( cleanupExpected(rightmostFailuresExpected), found, offset, errorPosition.line, errorPosition.column ); } return result; }, /* Returns the parser source code. */ toSource: function() { return this._source; } }; /* Thrown when a parser encounters a syntax error. */ result.SyntaxError = function(expected, found, offset, line, column) { function buildMessage(expected, found) { var expectedHumanized, foundHumanized; switch (expected.length) { case 0: expectedHumanized = "end of input"; break; case 1: expectedHumanized = expected[0]; break; default: expectedHumanized = expected.slice(0, expected.length - 1).join(", ") + " or " + expected[expected.length - 1]; } foundHumanized = found ? quote(found) : "end of input"; return "Expected " + expectedHumanized + " but " + foundHumanized + " found."; } this.name = "SyntaxError"; this.expected = expected; this.found = found; this.message = buildMessage(expected, found); this.offset = offset; this.line = line; this.column = column; }; result.SyntaxError.prototype = Error.prototype; return result; })(); }); define("amber_cli/AmberCli", ["amber_vm/smalltalk", "amber_vm/nil", "amber_vm/_st", "amber_core/Kernel-Objects"], function(smalltalk,nil,_st){ smalltalk.addPackage('AmberCli'); smalltalk.packages["AmberCli"].transport = {"type":"amd","amdNamespace":"amber_cli"}; smalltalk.addClass('AmberCli', smalltalk.Object, [], 'AmberCli'); smalltalk.AmberCli.comment="I am the Amber CLI (CommandLine Interface) tool which runs on Node.js.\x0a\x0aMy responsibility is to start different Amber programs like the FileServer or the Repl.\x0aWhich program to start is determined by the first commandline parameters passed to the AmberCli executable.\x0aUse `help` to get a list of all available options.\x0aAny further commandline parameters are passed to the specific program.\x0a\x0a## Commands\x0a\x0aNew commands can be added by creating a class side method in the `commands` protocol which takes one parameter.\x0aThis parameter is an array of all commandline options + values passed on to the program.\x0aAny `camelCaseCommand` is transformed into a commandline parameter of the form `camel-case-command` and vice versa."; smalltalk.addMethod( smalltalk.method({ selector: "commandLineSwitches", category: 'commandline', fn: function (){ var self=this; var switches; return smalltalk.withContext(function($ctx1) { var $1; switches=_st(_st(self._class())._methodsInProtocol_("commands"))._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._selector(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); switches=_st(switches)._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._match_("^[^:]*:$"); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); switches=_st(switches)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(each)._allButLast())._replace_with_("([A-Z])","-$1"))._asLowercase(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=switches; return $1; }, function($ctx1) {$ctx1.fill(self,"commandLineSwitches",{switches:switches},smalltalk.AmberCli.klass)})}, args: [], source: "commandLineSwitches\x0a\x09\x22Collect all methodnames from the 'commands' protocol of the class\x0a\x09 and select the ones with only one parameter.\x0a\x09 Then remove the ':' at the end of the name.\x0a\x09 Additionally all uppercase letters are made lowercase and preceded by a '-'.\x0a\x09 Example: fallbackPage: becomes --fallback-page.\x0a\x09 Return the Array containing the commandline switches.\x22\x0a\x09| switches |\x0a\x09switches := ((self class methodsInProtocol: 'commands') collect: [ :each | each selector]).\x0a\x09switches := switches select: [ :each | each match: '^[^:]*:$'].\x0a\x09switches :=switches collect: [ :each |\x0a\x09\x09(each allButLast replace: '([A-Z])' with: '-$1') asLowercase].\x0a\x09^switches", messageSends: ["collect:", "selector", "methodsInProtocol:", "class", "select:", "match:", "asLowercase", "replace:with:", "allButLast"], referencedClasses: [] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "handleArguments:", category: 'commandline', fn: function (args){ var self=this; var selector; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { selector=self._selectorForCommandLineSwitch_(_st(args)._first()); _st(args)._remove_(_st(args)._first()); self._perform_withArguments_(selector,_st($Array())._with_(args)); return self}, function($ctx1) {$ctx1.fill(self,"handleArguments:",{args:args,selector:selector},smalltalk.AmberCli.klass)})}, args: ["args"], source: "handleArguments: args\x0a\x09| selector |\x0a\x0a\x09selector := self selectorForCommandLineSwitch: (args first).\x0a\x09args remove: args first.\x0a\x09self perform: selector withArguments: (Array with: args)", messageSends: ["selectorForCommandLineSwitch:", "first", "remove:", "perform:withArguments:", "with:"], referencedClasses: ["Array"] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "help:", category: 'commands', fn: function (args){ var self=this; return smalltalk.withContext(function($ctx1) { _st(console)._log_("Available Commands:"); _st(self._commandLineSwitches())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(console)._log_(each); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"help:",{args:args},smalltalk.AmberCli.klass)})}, args: ["args"], source: "help: args\x0a\x09console log: 'Available Commands:'.\x0a\x09self commandLineSwitches do: [ :each | console log: each ]", messageSends: ["log:", "do:", "commandLineSwitches"], referencedClasses: [] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "main", category: 'startup', fn: function (){ var self=this; var args,nodeMinorVersion; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; nodeMinorVersion=_st(_st(_st(_st(process)._version())._tokenize_("."))._second())._asNumber(); $1=_st(nodeMinorVersion).__lt((8)); if(smalltalk.assert($1)){ _st(console)._log_("You are currently using Node.js ".__comma(_st(process)._version())); _st(console)._log_("Required is at least Node.js v0.8.x or greater."); return (-1); }; args=_st(process)._argv(); _st(args)._removeFrom_to_((1),(2)); $2=_st(args)._isEmpty(); if(smalltalk.assert($2)){ self._help_(nil); } else { $3=self._handleArguments_(args); return $3; }; return self}, function($ctx1) {$ctx1.fill(self,"main",{args:args,nodeMinorVersion:nodeMinorVersion},smalltalk.AmberCli.klass)})}, args: [], source: "main\x0a\x09\x22Main entry point for Amber applications.\x0a\x09Parses commandline arguments and starts the according subprogram.\x22\x0a\x09| args nodeMinorVersion |\x0a\x0a\x09nodeMinorVersion := ((process version) tokenize: '.') second asNumber.\x0a\x09nodeMinorVersion < 8 ifTrue: [\x0a\x09\x09console log: 'You are currently using Node.js ', (process version).\x0a\x09\x09console log: 'Required is at least Node.js v0.8.x or greater.'.\x0a\x09\x09^ -1.\x0a\x09].\x0a\x0a\x09args := process argv.\x0a\x09\x22Remove the first args which contain the path to the node executable and the script file.\x22\x0a\x09args removeFrom: 1 to: 2.\x0a\x09\x0a\x09(args isEmpty)\x0a\x09\x09ifTrue: [self help: nil]\x0a\x09\x09ifFalse: [^self handleArguments: args]", messageSends: ["asNumber", "second", "tokenize:", "version", "ifTrue:", "log:", ",", "<", "argv", "removeFrom:to:", "ifTrue:ifFalse:", "help:", "handleArguments:", "isEmpty"], referencedClasses: [] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "repl:", category: 'commands', fn: function (args){ var self=this; function $Repl(){return smalltalk.Repl||(typeof Repl=="undefined"?nil:Repl)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($Repl())._new())._createInterface(); return $1; }, function($ctx1) {$ctx1.fill(self,"repl:",{args:args},smalltalk.AmberCli.klass)})}, args: ["args"], source: "repl: args\x0a\x09^Repl new createInterface", messageSends: ["createInterface", "new"], referencedClasses: ["Repl"] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "selectorForCommandLineSwitch:", category: 'commandline', fn: function (aSwitch){ var self=this; var command,selector; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=_st(self._commandLineSwitches())._includes_(aSwitch); if(smalltalk.assert($1)){ selector=_st(_st(aSwitch)._replace_with_("-[a-z]",(function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._second())._asUppercase(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}))).__comma(":"); selector; } else { selector="help:"; selector; }; $2=selector; return $2; }, function($ctx1) {$ctx1.fill(self,"selectorForCommandLineSwitch:",{aSwitch:aSwitch,command:command,selector:selector},smalltalk.AmberCli.klass)})}, args: ["aSwitch"], source: "selectorForCommandLineSwitch: aSwitch\x0a\x09\x22Add ':' at the end and replace all occurences of a lowercase letter preceded by a '-' with the Uppercase letter.\x0a\x09 Example: fallback-page becomes fallbackPage:.\x0a\x09 If no correct selector is found return 'help:'\x22\x0a\x09 | command selector |\x0a\x0a\x09 (self commandLineSwitches includes: aSwitch)\x0a\x09 ifTrue: [ selector := (aSwitch replace: '-[a-z]' with: [ :each | each second asUppercase ]), ':']\x0a\x09 ifFalse: [ selector := 'help:' ].\x0a\x09^selector", messageSends: ["ifTrue:ifFalse:", ",", "replace:with:", "asUppercase", "second", "includes:", "commandLineSwitches"], referencedClasses: [] }), smalltalk.AmberCli.klass); smalltalk.addMethod( smalltalk.method({ selector: "serve:", category: 'commands', fn: function (args){ var self=this; function $FileServer(){return smalltalk.FileServer||(typeof FileServer=="undefined"?nil:FileServer)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($FileServer())._createServerWithArguments_(args))._start(); return $1; }, function($ctx1) {$ctx1.fill(self,"serve:",{args:args},smalltalk.AmberCli.klass)})}, args: ["args"], source: "serve: args\x0a\x09^(FileServer createServerWithArguments: args) start", messageSends: ["start", "createServerWithArguments:"], referencedClasses: ["FileServer"] }), smalltalk.AmberCli.klass); smalltalk.addClass('FileServer', smalltalk.Object, ['path', 'http', 'fs', 'url', 'host', 'port', 'basePath', 'util', 'username', 'password', 'fallbackPage'], 'AmberCli'); smalltalk.FileServer.comment="I am the Amber Smalltalk FileServer.\x0aMy runtime requirement is a functional Node.js executable.\x0a\x0aTo start a FileServer instance on port `4000` use the following code:\x0a\x0a FileServer new start\x0a\x0aA parameterized instance can be created with the following code:\x0a\x0a FileServer createServerWithArguments: options\x0a\x0aHere, `options` is an array of commandline style strings each followed by a value e.g. `#('--port', '6000', '--host', '0.0.0.0')`.\x0aA list of all available parameters can be printed to the commandline by passing `--help` as parameter.\x0aSee the `Options` section for further details on how options are mapped to instance methods.\x0a\x0aAfter startup FileServer checks if the directory layout required by Amber is present and logs a warning on absence.\x0a\x0a\x0a## Options\x0a\x0aEach option is of the form `--some-option-string` which is transformed into a selector of the format `someOptionString:`.\x0aThe trailing `--` gets removed, each `-[a-z]` gets transformed into the according uppercase letter, and a `:` is appended to create a selector which takes a single argument.\x0aAfterwards, the selector gets executed on the `FileServer` instance with the value following in the options array as parameter.\x0a\x0a## Adding new commandline parameters\x0a\x0aAdding new commandline parameters to `FileServer` is as easy as adding a new single parameter method to the `accessing` protocol."; smalltalk.addMethod( smalltalk.method({ selector: "base64Decode:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { return (new Buffer(aString, 'base64').toString()); return self}, function($ctx1) {$ctx1.fill(self,"base64Decode:",{aString:aString},smalltalk.FileServer)})}, args: ["aString"], source: "base64Decode: aString\x0a\x09", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "basePath", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@basePath"]; if(($receiver = $2) == nil || $receiver == undefined){ $1="./"; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"basePath",{},smalltalk.FileServer)})}, args: [], source: "basePath\x0a\x09^basePath ifNil: ['./']", messageSends: ["ifNil:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "basePath:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@basePath"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"basePath:",{aString:aString},smalltalk.FileServer)})}, args: ["aString"], source: "basePath: aString\x0a\x09basePath := aString", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "checkDirectoryLayout", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(self["@fs"])._existsSync_(_st(self._basePath()).__comma("index.html")); if(! smalltalk.assert($1)){ _st(console)._warn_("Warning: project directory does not contain index.html"); }; $2=_st(self["@fs"])._existsSync_(_st(self._basePath()).__comma("st")); if(! smalltalk.assert($2)){ _st(console)._warn_("Warning: project directory is missing an \x22st\x22 directory"); }; $3=_st(self["@fs"])._existsSync_(_st(self._basePath()).__comma("js")); if(! smalltalk.assert($3)){ _st(console)._warn_("Warning: project directory is missing a \x22js\x22 directory"); }; return self}, function($ctx1) {$ctx1.fill(self,"checkDirectoryLayout",{},smalltalk.FileServer)})}, args: [], source: "checkDirectoryLayout\x0a\x09(fs existsSync: self basePath, 'index.html') ifFalse: [\x0a\x09\x09console warn: 'Warning: project directory does not contain index.html'].\x0a\x09(fs existsSync: self basePath, 'st') ifFalse: [\x0a\x09\x09console warn: 'Warning: project directory is missing an \x22st\x22 directory'].\x0a\x09(fs existsSync: self basePath, 'js') ifFalse: [\x0a\x09\x09console warn: 'Warning: project directory is missing a \x22js\x22 directory'].", messageSends: ["ifFalse:", "warn:", "existsSync:", ",", "basePath"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "fallbackPage", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@fallbackPage"]; return $1; }, function($ctx1) {$ctx1.fill(self,"fallbackPage",{},smalltalk.FileServer)})}, args: [], source: "fallbackPage\x0a\x09^fallbackPage", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "fallbackPage:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { self["@fallbackPage"]=aString; return self}, function($ctx1) {$ctx1.fill(self,"fallbackPage:",{aString:aString},smalltalk.FileServer)})}, args: ["aString"], source: "fallbackPage: aString\x0a\x09fallbackPage := aString", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "handleGETRequest:respondTo:", category: 'request handling', fn: function (aRequest,aResponse){ var self=this; var uri,filename; return smalltalk.withContext(function($ctx1) { var $1; uri=_st(_st(self["@url"])._parse_(_st(aRequest)._url()))._pathname(); filename=_st(self["@path"])._join_with_(self._basePath(),uri); _st(self["@fs"])._exists_do_(filename,(function(aBoolean){ return smalltalk.withContext(function($ctx2) { $1=aBoolean; if(smalltalk.assert($1)){ return self._respondFileNamed_to_(filename,aResponse); } else { return self._respondNotFoundTo_(aResponse); }; }, function($ctx2) {$ctx2.fillBlock({aBoolean:aBoolean},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"handleGETRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse,uri:uri,filename:filename},smalltalk.FileServer)})}, args: ["aRequest", "aResponse"], source: "handleGETRequest: aRequest respondTo: aResponse\x0a\x09| uri filename |\x0a\x09uri := (url parse: aRequest url) pathname.\x0a\x09filename := path join: self basePath with: uri.\x0a\x09fs exists: filename do: [:aBoolean |\x0a\x09\x09aBoolean\x0a\x09\x09\x09ifFalse: [self respondNotFoundTo: aResponse]\x0a\x09\x09\x09ifTrue: [self respondFileNamed: filename to: aResponse]]", messageSends: ["pathname", "parse:", "url", "join:with:", "basePath", "exists:do:", "ifFalse:ifTrue:", "respondNotFoundTo:", "respondFileNamed:to:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "handleOPTIONSRequest:respondTo:", category: 'request handling', fn: function (aRequest,aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { _st(aResponse)._writeHead_options_((200),smalltalk.HashedCollection._from_(["Access-Control-Allow-Origin".__minus_gt("*"),"Access-Control-Allow-Methods".__minus_gt("GET, PUT, POST, DELETE, OPTIONS"),"Access-Control-Allow-Headers".__minus_gt("Content-Type, Accept"),"Content-Length".__minus_gt((0)),"Access-Control-Max-Age".__minus_gt((10))])); _st(aResponse)._end(); return self}, function($ctx1) {$ctx1.fill(self,"handleOPTIONSRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse},smalltalk.FileServer)})}, args: ["aRequest", "aResponse"], source: "handleOPTIONSRequest: aRequest respondTo: aResponse\x0a\x09aResponse writeHead: 200 options: #{'Access-Control-Allow-Origin' -> '*'.\x0a\x09\x09\x09\x09\x09'Access-Control-Allow-Methods' -> 'GET, PUT, POST, DELETE, OPTIONS'.\x0a\x09\x09\x09\x09\x09'Access-Control-Allow-Headers' -> 'Content-Type, Accept'.\x0a\x09\x09\x09\x09\x09'Content-Length' -> 0.\x0a\x09\x09\x09\x09\x09'Access-Control-Max-Age' -> 10}.\x0a\x09aResponse end", messageSends: ["writeHead:options:", "->", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "handlePUTRequest:respondTo:", category: 'request handling', fn: function (aRequest,aResponse){ var self=this; var file,stream; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self._isAuthenticated_(aRequest); if(! smalltalk.assert($1)){ self._respondAuthenticationRequiredTo_(aResponse); return nil; }; file=".".__comma(_st(aRequest)._url()); stream=_st(self["@fs"])._createWriteStream_(file); _st(stream)._on_do_("error",(function(error){ return smalltalk.withContext(function($ctx2) { _st(console)._warn_("Error creating WriteStream for file ".__comma(file)); _st(console)._warn_(" Did you forget to create the necessary js/ or st/ directory in your project?"); _st(console)._warn_(" The exact error is: ".__comma(error)); return self._respondNotCreatedTo_(aResponse); }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1)})})); _st(stream)._on_do_("close",(function(){ return smalltalk.withContext(function($ctx2) { return self._respondCreatedTo_(aResponse); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); _st(aRequest)._setEncoding_("utf8"); _st(aRequest)._on_do_("data",(function(data){ return smalltalk.withContext(function($ctx2) { return _st(stream)._write_(data); }, function($ctx2) {$ctx2.fillBlock({data:data},$ctx1)})})); _st(aRequest)._on_do_("end",(function(){ return smalltalk.withContext(function($ctx2) { $2=_st(stream)._writable(); if(smalltalk.assert($2)){ return _st(stream)._end(); }; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"handlePUTRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse,file:file,stream:stream},smalltalk.FileServer)})}, args: ["aRequest", "aResponse"], source: "handlePUTRequest: aRequest respondTo: aResponse\x0a\x09| file stream |\x0a\x09(self isAuthenticated: aRequest)\x0a\x09\x09ifFalse: [self respondAuthenticationRequiredTo: aResponse. ^nil].\x0a\x0a\x09file := '.', aRequest url.\x0a\x09stream := fs createWriteStream: file.\x0a\x0a\x09stream on: 'error' do: [:error |\x0a\x09\x09console warn: 'Error creating WriteStream for file ', file.\x0a\x09\x09console warn: ' Did you forget to create the necessary js/ or st/ directory in your project?'.\x0a\x09\x09console warn: ' The exact error is: ', error.\x0a\x09\x09self respondNotCreatedTo: aResponse].\x0a\x0a\x09stream on: 'close' do: [\x0a\x09\x09self respondCreatedTo: aResponse].\x0a\x0a\x09aRequest setEncoding: 'utf8'.\x0a\x09aRequest on: 'data' do: [:data |\x0a\x09\x09stream write: data].\x0a\x0a\x09aRequest on: 'end' do: [\x0a\x09\x09stream writable ifTrue: [stream end]]", messageSends: ["ifFalse:", "respondAuthenticationRequiredTo:", "isAuthenticated:", ",", "url", "createWriteStream:", "on:do:", "warn:", "respondNotCreatedTo:", "respondCreatedTo:", "setEncoding:", "write:", "ifTrue:", "end", "writable"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "handleRequest:respondTo:", category: 'request handling', fn: function (aRequest,aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(_st(aRequest)._method()).__eq("PUT"); if(smalltalk.assert($1)){ self._handlePUTRequest_respondTo_(aRequest,aResponse); }; $2=_st(_st(aRequest)._method()).__eq("GET"); if(smalltalk.assert($2)){ self._handleGETRequest_respondTo_(aRequest,aResponse); }; $3=_st(_st(aRequest)._method()).__eq("OPTIONS"); if(smalltalk.assert($3)){ self._handleOPTIONSRequest_respondTo_(aRequest,aResponse); }; return self}, function($ctx1) {$ctx1.fill(self,"handleRequest:respondTo:",{aRequest:aRequest,aResponse:aResponse},smalltalk.FileServer)})}, args: ["aRequest", "aResponse"], source: "handleRequest: aRequest respondTo: aResponse\x0a\x09aRequest method = 'PUT'\x0a\x09\x09ifTrue: [self handlePUTRequest: aRequest respondTo: aResponse].\x0a\x09aRequest method = 'GET'\x0a\x09\x09ifTrue:[self handleGETRequest: aRequest respondTo: aResponse].\x0a\x09aRequest method = 'OPTIONS'\x0a\x09\x09ifTrue:[self handleOPTIONSRequest: aRequest respondTo: aResponse]", messageSends: ["ifTrue:", "handlePUTRequest:respondTo:", "=", "method", "handleGETRequest:respondTo:", "handleOPTIONSRequest:respondTo:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "host", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@host"]; return $1; }, function($ctx1) {$ctx1.fill(self,"host",{},smalltalk.FileServer)})}, args: [], source: "host\x0a\x09^host", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "host:", category: 'accessing', fn: function (hostname){ var self=this; return smalltalk.withContext(function($ctx1) { self["@host"]=hostname; return self}, function($ctx1) {$ctx1.fill(self,"host:",{hostname:hostname},smalltalk.FileServer)})}, args: ["hostname"], source: "host: hostname\x0a\x09host := hostname", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { smalltalk.FileServer.superclass.fn.prototype._initialize.apply(_st(self), []); self["@path"]=self._require_("path"); self["@http"]=self._require_("http"); self["@fs"]=self._require_("fs"); self["@util"]=self._require_("util"); self["@url"]=self._require_("url"); self["@host"]=_st(self._class())._defaultHost(); self["@port"]=_st(self._class())._defaultPort(); self["@username"]=nil; self["@password"]=nil; self["@fallbackPage"]=nil; return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.FileServer)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09path := self require: 'path'.\x0a\x09http := self require: 'http'.\x0a\x09fs := self require: 'fs'.\x0a\x09util := self require: 'util'.\x0a\x09url := self require: 'url'.\x0a\x09host := self class defaultHost.\x0a\x09port := self class defaultPort.\x0a\x09username := nil.\x0a\x09password := nil.\x0a\x09fallbackPage := nil.", messageSends: ["initialize", "require:", "defaultHost", "class", "defaultPort"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "isAuthenticated:", category: 'private', fn: function (aRequest){ var self=this; var header,token,auth,parts; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; $1=_st(_st(self["@username"])._isNil())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@password"])._isNil(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($1)){ return true; }; $2=_st(_st(aRequest)._headers())._at_("authorization"); if(($receiver = $2) == nil || $receiver == undefined){ header=""; } else { header=$2; }; $3=_st(header)._isEmpty(); if(smalltalk.assert($3)){ return false; } else { $4=_st(header)._tokenize_(" "); if(($receiver = $4) == nil || $receiver == undefined){ token=""; } else { token=$4; }; token; auth=self._base64Decode_(_st(token)._at_((2))); auth; parts=_st(auth)._tokenize_(":"); parts; $5=_st(_st(self["@username"]).__eq(_st(parts)._at_((1))))._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@password"]).__eq(_st(parts)._at_((2))); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($5)){ return true; } else { return false; }; }; return self}, function($ctx1) {$ctx1.fill(self,"isAuthenticated:",{aRequest:aRequest,header:header,token:token,auth:auth,parts:parts},smalltalk.FileServer)})}, args: ["aRequest"], source: "isAuthenticated: aRequest\x0a\x09\x22Basic HTTP Auth: http://stackoverflow.com/a/5957629/293175\x0a\x09 and https://gist.github.com/1686663\x22\x0a\x09| header token auth parts|\x0a\x0a\x09(username isNil and: [password isNil]) ifTrue: [^true].\x0a\x0a\x09\x22get authentication header\x22\x0a\x09header := (aRequest headers at: 'authorization') ifNil:[''].\x0a\x09(header isEmpty)\x0a\x09ifTrue: [^false]\x0a\x09ifFalse: [\x0a\x09\x09\x22get authentication token\x22\x0a\x09\x09token := (header tokenize: ' ') ifNil:[''].\x0a\x09\x09\x22convert back from base64\x22\x0a\x09\x09auth := self base64Decode: (token at: 2).\x0a\x09\x09\x22split token at colon\x22\x0a\x09\x09parts := auth tokenize: ':'.\x0a\x0a\x09\x09((username = (parts at: 1)) and: [password = (parts at: 2)])\x0a\x09\x09\x09ifTrue: [^true]\x0a\x09\x09\x09ifFalse: [^false]\x0a\x09].", messageSends: ["ifTrue:", "and:", "isNil", "ifNil:", "at:", "headers", "ifTrue:ifFalse:", "tokenize:", "base64Decode:", "=", "isEmpty"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "password:", category: 'accessing', fn: function (aPassword){ var self=this; return smalltalk.withContext(function($ctx1) { self["@password"]=aPassword; return self}, function($ctx1) {$ctx1.fill(self,"password:",{aPassword:aPassword},smalltalk.FileServer)})}, args: ["aPassword"], source: "password: aPassword\x0a\x09password := aPassword.", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "port", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@port"]; return $1; }, function($ctx1) {$ctx1.fill(self,"port",{},smalltalk.FileServer)})}, args: [], source: "port\x0a\x09^port", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "port:", category: 'accessing', fn: function (aNumber){ var self=this; return smalltalk.withContext(function($ctx1) { self["@port"]=aNumber; return self}, function($ctx1) {$ctx1.fill(self,"port:",{aNumber:aNumber},smalltalk.FileServer)})}, args: ["aNumber"], source: "port: aNumber\x0a\x09port := aNumber", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "require:", category: 'private', fn: function (aModuleString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(require)._value_(aModuleString); return $1; }, function($ctx1) {$ctx1.fill(self,"require:",{aModuleString:aModuleString},smalltalk.FileServer)})}, args: ["aModuleString"], source: "require: aModuleString\x0a\x09\x22call to the require function\x22\x0a\x09^require value: aModuleString", messageSends: ["value:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondAuthenticationRequiredTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aResponse; _st($1)._writeHead_options_((401),smalltalk.HashedCollection._from_(["WWW-Authenticate".__minus_gt("Basic realm=\x22Secured Developer Area\x22")])); _st($1)._write_("Authentication needed"); $2=_st($1)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondAuthenticationRequiredTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondAuthenticationRequiredTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 401 options: #{'WWW-Authenticate' -> 'Basic realm=\x22Secured Developer Area\x22'};\x0a\x09\x09write: 'Authentication needed';\x0a\x09\x09end.", messageSends: ["writeHead:options:", "->", "write:", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondCreatedTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aResponse; _st($1)._writeHead_options_((201),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt("text/plain"),"Access-Control-Allow-Origin".__minus_gt("*")])); $2=_st($1)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondCreatedTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondCreatedTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 201 options: #{'Content-Type' -> 'text/plain'. 'Access-Control-Allow-Origin' -> '*'};\x0a\x09\x09end.", messageSends: ["writeHead:options:", "->", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondFileNamed:to:", category: 'request handling', fn: function (aFilename,aResponse){ var self=this; var type,filename; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; filename=aFilename; $1=_st(_st(self["@fs"])._statSync_(aFilename))._isDirectory(); if(smalltalk.assert($1)){ filename=_st(filename).__comma("index.html"); filename; }; _st(self["@fs"])._readFile_do_(filename,(function(ex,file){ return smalltalk.withContext(function($ctx2) { $2=_st(ex)._notNil(); if(smalltalk.assert($2)){ _st(console)._log_(_st(filename).__comma(" does not exist")); return self._respondInternalErrorTo_(aResponse); } else { type=_st(self._class())._mimeTypeFor_(filename); type; $3=_st(type).__eq("application/javascript"); if(smalltalk.assert($3)){ type=_st(type).__comma(";charset=utf-8"); type; }; $4=aResponse; _st($4)._writeHead_options_((200),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt(type)])); _st($4)._write_encoding_(file,"binary"); $5=_st($4)._end(); return $5; }; }, function($ctx2) {$ctx2.fillBlock({ex:ex,file:file},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"respondFileNamed:to:",{aFilename:aFilename,aResponse:aResponse,type:type,filename:filename},smalltalk.FileServer)})}, args: ["aFilename", "aResponse"], source: "respondFileNamed: aFilename to: aResponse\x0a\x09| type filename |\x0a\x0a\x09filename := aFilename.\x0a\x09(fs statSync: aFilename) isDirectory ifTrue: [\x0a\x09\x09filename := filename, 'index.html'].\x0a\x0a\x09fs readFile: filename do: [:ex :file |\x0a\x09\x09ex notNil \x0a\x09\x09\x09ifTrue: [\x0a\x09\x09\x09\x09console log: filename, ' does not exist'.\x0a\x09\x09\x09\x09self respondInternalErrorTo: aResponse]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09type := self class mimeTypeFor: filename.\x0a\x09\x09\x09\x09type = 'application/javascript'\x0a\x09\x09\x09\x09\x09ifTrue: [ type:=type,';charset=utf-8' ].\x0a\x09\x09\x09\x09aResponse \x0a\x09\x09\x09\x09\x09writeHead: 200 options: #{'Content-Type' -> type};\x0a\x09\x09\x09\x09\x09write: file encoding: 'binary';\x0a\x09\x09\x09\x09\x09end]]", messageSends: ["ifTrue:", ",", "isDirectory", "statSync:", "readFile:do:", "ifTrue:ifFalse:", "log:", "respondInternalErrorTo:", "mimeTypeFor:", "class", "=", "writeHead:options:", "->", "write:encoding:", "end", "notNil"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondInternalErrorTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aResponse; _st($1)._writeHead_options_((500),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt("text/plain")])); _st($1)._write_("500 Internal server error"); $2=_st($1)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondInternalErrorTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondInternalErrorTo: aResponse\x0a\x09aResponse \x0a\x09\x09writeHead: 500 options: #{'Content-Type' -> 'text/plain'};\x0a\x09\x09write: '500 Internal server error';\x0a\x09\x09end", messageSends: ["writeHead:options:", "->", "write:", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondNotCreatedTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aResponse; _st($1)._writeHead_options_((400),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt("text/plain")])); _st($1)._write_("File could not be created. Did you forget to create the st/js directories on the server?"); $2=_st($1)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondNotCreatedTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondNotCreatedTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 400 options: #{'Content-Type' -> 'text/plain'};\x0a\x09\x09write: 'File could not be created. Did you forget to create the st/js directories on the server?';\x0a\x09\x09end.", messageSends: ["writeHead:options:", "->", "write:", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondNotFoundTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4; $1=_st(self._fallbackPage())._isNil(); if(! smalltalk.assert($1)){ $2=self._respondFileNamed_to_(self._fallbackPage(),aResponse); return $2; }; $3=aResponse; _st($3)._writeHead_options_((404),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt("text/plain")])); _st($3)._write_("404 Not found"); $4=_st($3)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondNotFoundTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondNotFoundTo: aResponse\x0a\x09self fallbackPage isNil ifFalse: [^self respondFileNamed: self fallbackPage to: aResponse].\x0a\x09aResponse \x0a\x09\x09writeHead: 404 options: #{'Content-Type' -> 'text/plain'};\x0a\x09\x09write: '404 Not found';\x0a\x09\x09end", messageSends: ["ifFalse:", "respondFileNamed:to:", "fallbackPage", "isNil", "writeHead:options:", "->", "write:", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "respondOKTo:", category: 'request handling', fn: function (aResponse){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=aResponse; _st($1)._writeHead_options_((200),smalltalk.HashedCollection._from_(["Content-Type".__minus_gt("text/plain"),"Access-Control-Allow-Origin".__minus_gt("*")])); $2=_st($1)._end(); return self}, function($ctx1) {$ctx1.fill(self,"respondOKTo:",{aResponse:aResponse},smalltalk.FileServer)})}, args: ["aResponse"], source: "respondOKTo: aResponse\x0a\x09aResponse\x0a\x09\x09writeHead: 200 options: #{'Content-Type' -> 'text/plain'. 'Access-Control-Allow-Origin' -> '*'};\x0a\x09\x09end.", messageSends: ["writeHead:options:", "->", "end"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "start", category: 'starting', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self._checkDirectoryLayout(); $1=_st(self["@http"])._createServer_((function(request,response){ return smalltalk.withContext(function($ctx2) { return self._handleRequest_respondTo_(request,response); }, function($ctx2) {$ctx2.fillBlock({request:request,response:response},$ctx1)})})); _st($1)._on_do_("error",(function(error){ return smalltalk.withContext(function($ctx2) { return _st(console)._log_("Error starting server: ".__comma(error)); }, function($ctx2) {$ctx2.fillBlock({error:error},$ctx1)})})); _st($1)._on_do_("listening",(function(){ return smalltalk.withContext(function($ctx2) { return _st(console)._log_(_st(_st("Starting file server on http://".__comma(self._host())).__comma(":")).__comma(_st(self._port())._asString())); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $2=_st($1)._listen_host_(self._port(),self._host()); return self}, function($ctx1) {$ctx1.fill(self,"start",{},smalltalk.FileServer)})}, args: [], source: "start\x0a\x09\x22Checks if required directory layout is present (issue warning if not).\x0a\x09 Afterwards start the server.\x22\x0a\x09self checkDirectoryLayout.\x0a\x09(http createServer: [:request :response |\x0a\x09 self handleRequest: request respondTo: response])\x0a\x09 on: 'error' do: [:error | console log: 'Error starting server: ', error];\x0a\x09 on: 'listening' do: [console log: 'Starting file server on http://', self host, ':', self port asString];\x0a\x09 listen: self port host: self host.", messageSends: ["checkDirectoryLayout", "on:do:", "log:", ",", "createServer:", "handleRequest:respondTo:", "asString", "port", "host", "listen:host:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "startOn:", category: 'starting', fn: function (aPort){ var self=this; return smalltalk.withContext(function($ctx1) { self._port_(aPort); self._start(); return self}, function($ctx1) {$ctx1.fill(self,"startOn:",{aPort:aPort},smalltalk.FileServer)})}, args: ["aPort"], source: "startOn: aPort\x0a\x09self port: aPort.\x0a\x09self start", messageSends: ["port:", "start"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "username:", category: 'accessing', fn: function (aUsername){ var self=this; return smalltalk.withContext(function($ctx1) { self["@username"]=aUsername; return self}, function($ctx1) {$ctx1.fill(self,"username:",{aUsername:aUsername},smalltalk.FileServer)})}, args: ["aUsername"], source: "username: aUsername\x0a\x09username := aUsername.", messageSends: [], referencedClasses: [] }), smalltalk.FileServer); smalltalk.addMethod( smalltalk.method({ selector: "writeData:toFileNamed:", category: 'private', fn: function (data,aFilename){ var self=this; return smalltalk.withContext(function($ctx1) { _st(console)._log_(aFilename); return self}, function($ctx1) {$ctx1.fill(self,"writeData:toFileNamed:",{data:data,aFilename:aFilename},smalltalk.FileServer)})}, args: ["data", "aFilename"], source: "writeData: data toFileNamed: aFilename\x0a\x09console log: aFilename", messageSends: ["log:"], referencedClasses: [] }), smalltalk.FileServer); smalltalk.FileServer.klass.iVarNames = ['mimeTypes']; smalltalk.addMethod( smalltalk.method({ selector: "commandLineSwitches", category: 'accessing', fn: function (){ var self=this; var switches; return smalltalk.withContext(function($ctx1) { var $1; switches=_st(self._methodsInProtocol_("accessing"))._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._selector(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); switches=_st(switches)._select_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(each)._match_("^[^:]*:$"); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); switches=_st(switches)._collect_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(_st(_st(each)._allButLast())._replace_with_("([A-Z])","-$1"))._asLowercase())._replace_with_("^([a-z])","--$1"); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); $1=switches; return $1; }, function($ctx1) {$ctx1.fill(self,"commandLineSwitches",{switches:switches},smalltalk.FileServer.klass)})}, args: [], source: "commandLineSwitches\x0a\x09\x22Collect all methodnames from the 'accessing' protocol\x0a\x09 and select the ones with only one parameter.\x0a\x09 Then remove the ':' at the end of the name\x0a\x09 and add a '--' at the beginning.\x0a\x09 Additionally all uppercase letters are made lowercase and preceded by a '-'.\x0a\x09 Example: fallbackPage: becomes --fallback-page.\x0a\x09 Return the Array containing the commandline switches.\x22\x0a\x09| switches |\x0a\x09switches := ((self methodsInProtocol: 'accessing') collect: [ :each | each selector]).\x0a\x09switches := switches select: [ :each | each match: '^[^:]*:$'].\x0a\x09switches :=switches collect: [ :each |\x0a\x09\x09(each allButLast replace: '([A-Z])' with: '-$1') asLowercase replace: '^([a-z])' with: '--$1' ].\x0a\x09^switches", messageSends: ["collect:", "selector", "methodsInProtocol:", "select:", "match:", "replace:with:", "asLowercase", "allButLast"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "createServerWithArguments:", category: 'initialization', fn: function (options){ var self=this; var server,popFront,front,optionName,optionValue,switches; function $Array(){return smalltalk.Array||(typeof Array=="undefined"?nil:Array)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3,$4,$5; var $early={}; try { switches=self._commandLineSwitches(); server=self._new(); _st(options)._ifEmpty_((function(){ return smalltalk.withContext(function($ctx2) { $1=server; throw $early=[$1]; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $2=_st(_st(options)._size())._even(); if(! smalltalk.assert($2)){ _st(console)._log_("Using default parameters."); _st(console)._log_("Wrong commandline options or not enough arguments for: ".__comma(options)); _st(console)._log_("Use any of the following ones: ".__comma(switches)); $3=server; return $3; }; popFront=(function(args){ return smalltalk.withContext(function($ctx2) { front=_st(args)._first(); front; _st(args)._remove_(front); return front; }, function($ctx2) {$ctx2.fillBlock({args:args},$ctx1)})}); _st((function(){ return smalltalk.withContext(function($ctx2) { return _st(options)._notEmpty(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._whileTrue_((function(){ return smalltalk.withContext(function($ctx2) { optionName=_st(popFront)._value_(options); optionName; optionValue=_st(popFront)._value_(options); optionValue; $4=_st(switches)._includes_(optionName); if(smalltalk.assert($4)){ optionName=self._selectorForCommandLineSwitch_(optionName); optionName; return _st(server)._perform_withArguments_(optionName,_st($Array())._with_(optionValue)); } else { _st(console)._log_(_st(optionName).__comma(" is not a valid commandline option")); return _st(console)._log_("Use any of the following ones: ".__comma(switches)); }; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $5=server; return $5; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"createServerWithArguments:",{options:options,server:server,popFront:popFront,front:front,optionName:optionName,optionValue:optionValue,switches:switches},smalltalk.FileServer.klass)})}, args: ["options"], source: "createServerWithArguments: options\x0a\x09\x22If options are empty return a default FileServer instance.\x0a\x09 If options are given loop through them and set the passed in values\x0a\x09 on the FileServer instance.\x0a\x09 \x0a\x09 Commanline options map directly to methods in the 'accessing' protocol\x0a\x09 taking one parameter.\x0a\x09 Adding a method to this protocol makes it directly settable through\x0a\x09 command line options.\x0a\x09 \x22\x0a\x09| server popFront front optionName optionValue switches |\x0a\x0a\x09switches := self commandLineSwitches.\x0a\x0a\x09server := self new.\x0a\x0a\x09options ifEmpty: [^server].\x0a\x0a\x09(options size even) ifFalse: [\x0a\x09\x09console log: 'Using default parameters.'.\x0a\x09\x09console log: 'Wrong commandline options or not enough arguments for: ' , options.\x0a\x09\x09console log: 'Use any of the following ones: ', switches.\x0a\x09\x09^server].\x0a\x0a\x09popFront := [:args |\x0a\x09\x09front := args first.\x0a\x09\x09args remove: front.\x0a\x09\x09front].\x0a\x0a\x09[options notEmpty] whileTrue: [\x0a\x09\x09optionName := popFront value: options.\x0a\x09\x09optionValue := popFront value: options.\x0a\x0a\x09\x09(switches includes: optionName) ifTrue: [\x0a\x09\x09\x09optionName := self selectorForCommandLineSwitch: optionName.\x0a\x09\x09\x09server perform: optionName withArguments: (Array with: optionValue)]\x0a\x09\x09\x09ifFalse: [\x0a\x09\x09\x09\x09console log: optionName, ' is not a valid commandline option'.\x0a\x09\x09\x09\x09console log: 'Use any of the following ones: ', switches ]].\x0a\x09^server.", messageSends: ["commandLineSwitches", "new", "ifEmpty:", "ifFalse:", "log:", ",", "even", "size", "first", "remove:", "whileTrue:", "value:", "ifTrue:ifFalse:", "selectorForCommandLineSwitch:", "perform:withArguments:", "with:", "includes:", "notEmpty"], referencedClasses: ["Array"] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "defaultHost", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "127.0.0.1"; }, function($ctx1) {$ctx1.fill(self,"defaultHost",{},smalltalk.FileServer.klass)})}, args: [], source: "defaultHost\x0a\x09^'127.0.0.1'", messageSends: [], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "defaultMimeTypes", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=smalltalk.HashedCollection._from_(["%".__minus_gt("application/x-trash"),"323".__minus_gt("text/h323"),"abw".__minus_gt("application/x-abiword"),"ai".__minus_gt("application/postscript"),"aif".__minus_gt("audio/x-aiff"),"aifc".__minus_gt("audio/x-aiff"),"aiff".__minus_gt("audio/x-aiff"),"alc".__minus_gt("chemical/x-alchemy"),"art".__minus_gt("image/x-jg"),"asc".__minus_gt("text/plain"),"asf".__minus_gt("video/x-ms-asf"),"asn".__minus_gt("chemical/x-ncbi-asn1-spec"),"aso".__minus_gt("chemical/x-ncbi-asn1-binary"),"asx".__minus_gt("video/x-ms-asf"),"au".__minus_gt("audio/basic"),"avi".__minus_gt("video/x-msvideo"),"b".__minus_gt("chemical/x-molconn-Z"),"bak".__minus_gt("application/x-trash"),"bat".__minus_gt("application/x-msdos-program"),"bcpio".__minus_gt("application/x-bcpio"),"bib".__minus_gt("text/x-bibtex"),"bin".__minus_gt("application/octet-stream"),"bmp".__minus_gt("image/x-ms-bmp"),"book".__minus_gt("application/x-maker"),"bsd".__minus_gt("chemical/x-crossfire"),"c".__minus_gt("text/x-csrc"),"c++".__minus_gt("text/x-c++src"),"c3d".__minus_gt("chemical/x-chem3d"),"cac".__minus_gt("chemical/x-cache"),"cache".__minus_gt("chemical/x-cache"),"cascii".__minus_gt("chemical/x-cactvs-binary"),"cat".__minus_gt("application/vnd.ms-pki.seccat"),"cbin".__minus_gt("chemical/x-cactvs-binary"),"cc".__minus_gt("text/x-c++src"),"cdf".__minus_gt("application/x-cdf"),"cdr".__minus_gt("image/x-coreldraw"),"cdt".__minus_gt("image/x-coreldrawtemplate"),"cdx".__minus_gt("chemical/x-cdx"),"cdy".__minus_gt("application/vnd.cinderella"),"cef".__minus_gt("chemical/x-cxf"),"cer".__minus_gt("chemical/x-cerius"),"chm".__minus_gt("chemical/x-chemdraw"),"chrt".__minus_gt("application/x-kchart"),"cif".__minus_gt("chemical/x-cif"),"class".__minus_gt("application/java-vm"),"cls".__minus_gt("text/x-tex"),"cmdf".__minus_gt("chemical/x-cmdf"),"cml".__minus_gt("chemical/x-cml"),"cod".__minus_gt("application/vnd.rim.cod"),"com".__minus_gt("application/x-msdos-program"),"cpa".__minus_gt("chemical/x-compass"),"cpio".__minus_gt("application/x-cpio"),"cpp".__minus_gt("text/x-c++src"),"cpt".__minus_gt("image/x-corelphotopaint"),"crl".__minus_gt("application/x-pkcs7-crl"),"crt".__minus_gt("application/x-x509-ca-cert"),"csf".__minus_gt("chemical/x-cache-csf"),"csh".__minus_gt("text/x-csh"),"csm".__minus_gt("chemical/x-csml"),"csml".__minus_gt("chemical/x-csml"),"css".__minus_gt("text/css"),"csv".__minus_gt("text/comma-separated-values"),"ctab".__minus_gt("chemical/x-cactvs-binary"),"ctx".__minus_gt("chemical/x-ctx"),"cu".__minus_gt("application/cu-seeme"),"cub".__minus_gt("chemical/x-gaussian-cube"),"cxf".__minus_gt("chemical/x-cxf"),"cxx".__minus_gt("text/x-c++src"),"dat".__minus_gt("chemical/x-mopac-input"),"dcr".__minus_gt("application/x-director"),"deb".__minus_gt("application/x-debian-package"),"dif".__minus_gt("video/dv"),"diff".__minus_gt("text/plain"),"dir".__minus_gt("application/x-director"),"djv".__minus_gt("image/vnd.djvu"),"djvu".__minus_gt("image/vnd.djvu"),"dl".__minus_gt("video/dl"),"dll".__minus_gt("application/x-msdos-program"),"dmg".__minus_gt("application/x-apple-diskimage"),"dms".__minus_gt("application/x-dms"),"doc".__minus_gt("application/msword"),"dot".__minus_gt("application/msword"),"dv".__minus_gt("video/dv"),"dvi".__minus_gt("application/x-dvi"),"dx".__minus_gt("chemical/x-jcamp-dx"),"dxr".__minus_gt("application/x-director"),"emb".__minus_gt("chemical/x-embl-dl-nucleotide"),"embl".__minus_gt("chemical/x-embl-dl-nucleotide"),"ent".__minus_gt("chemical/x-pdb"),"eps".__minus_gt("application/postscript"),"etx".__minus_gt("text/x-setext"),"exe".__minus_gt("application/x-msdos-program"),"ez".__minus_gt("application/andrew-inset"),"fb".__minus_gt("application/x-maker"),"fbdoc".__minus_gt("application/x-maker"),"fch".__minus_gt("chemical/x-gaussian-checkpoint"),"fchk".__minus_gt("chemical/x-gaussian-checkpoint"),"fig".__minus_gt("application/x-xfig"),"flac".__minus_gt("application/x-flac"),"fli".__minus_gt("video/fli"),"fm".__minus_gt("application/x-maker"),"frame".__minus_gt("application/x-maker"),"frm".__minus_gt("application/x-maker"),"gal".__minus_gt("chemical/x-gaussian-log"),"gam".__minus_gt("chemical/x-gamess-input"),"gamin".__minus_gt("chemical/x-gamess-input"),"gau".__minus_gt("chemical/x-gaussian-input"),"gcd".__minus_gt("text/x-pcs-gcd"),"gcf".__minus_gt("application/x-graphing-calculator"),"gcg".__minus_gt("chemical/x-gcg8-sequence"),"gen".__minus_gt("chemical/x-genbank"),"gf".__minus_gt("application/x-tex-gf"),"gif".__minus_gt("image/gif"),"gjc".__minus_gt("chemical/x-gaussian-input"),"gjf".__minus_gt("chemical/x-gaussian-input"),"gl".__minus_gt("video/gl"),"gnumeric".__minus_gt("application/x-gnumeric"),"gpt".__minus_gt("chemical/x-mopac-graph"),"gsf".__minus_gt("application/x-font"),"gsm".__minus_gt("audio/x-gsm"),"gtar".__minus_gt("application/x-gtar"),"h".__minus_gt("text/x-chdr"),"h++".__minus_gt("text/x-c++hdr"),"hdf".__minus_gt("application/x-hdf"),"hh".__minus_gt("text/x-c++hdr"),"hin".__minus_gt("chemical/x-hin"),"hpp".__minus_gt("text/x-c++hdr"),"hqx".__minus_gt("application/mac-binhex40"),"hs".__minus_gt("text/x-haskell"),"hta".__minus_gt("application/hta"),"htc".__minus_gt("text/x-component"),"htm".__minus_gt("text/html"),"html".__minus_gt("text/html"),"hxx".__minus_gt("text/x-c++hdr"),"ica".__minus_gt("application/x-ica"),"ice".__minus_gt("x-conference/x-cooltalk"),"ico".__minus_gt("image/x-icon"),"ics".__minus_gt("text/calendar"),"icz".__minus_gt("text/calendar"),"ief".__minus_gt("image/ief"),"iges".__minus_gt("model/iges"),"igs".__minus_gt("model/iges"),"iii".__minus_gt("application/x-iphone"),"inp".__minus_gt("chemical/x-gamess-input"),"ins".__minus_gt("application/x-internet-signup"),"iso".__minus_gt("application/x-iso9660-image"),"isp".__minus_gt("application/x-internet-signup"),"ist".__minus_gt("chemical/x-isostar"),"istr".__minus_gt("chemical/x-isostar"),"jad".__minus_gt("text/vnd.sun.j2me.app-descriptor"),"jar".__minus_gt("application/java-archive"),"java".__minus_gt("text/x-java"),"jdx".__minus_gt("chemical/x-jcamp-dx"),"jmz".__minus_gt("application/x-jmol"),"jng".__minus_gt("image/x-jng"),"jnlp".__minus_gt("application/x-java-jnlp-file"),"jpe".__minus_gt("image/jpeg"),"jpeg".__minus_gt("image/jpeg"),"jpg".__minus_gt("image/jpeg"),"js".__minus_gt("application/javascript"),"kar".__minus_gt("audio/midi"),"key".__minus_gt("application/pgp-keys"),"kil".__minus_gt("application/x-killustrator"),"kin".__minus_gt("chemical/x-kinemage"),"kpr".__minus_gt("application/x-kpresenter"),"kpt".__minus_gt("application/x-kpresenter"),"ksp".__minus_gt("application/x-kspread"),"kwd".__minus_gt("application/x-kword"),"kwt".__minus_gt("application/x-kword"),"latex".__minus_gt("application/x-latex"),"lha".__minus_gt("application/x-lha"),"lhs".__minus_gt("text/x-literate-haskell"),"lsf".__minus_gt("video/x-la-asf"),"lsx".__minus_gt("video/x-la-asf"),"ltx".__minus_gt("text/x-tex"),"lzh".__minus_gt("application/x-lzh"),"lzx".__minus_gt("application/x-lzx"),"m3u".__minus_gt("audio/x-mpegurl"),"m4a".__minus_gt("audio/mpeg"),"maker".__minus_gt("application/x-maker"),"man".__minus_gt("application/x-troff-man"),"mcif".__minus_gt("chemical/x-mmcif"),"mcm".__minus_gt("chemical/x-macmolecule"),"mdb".__minus_gt("application/msaccess"),"me".__minus_gt("application/x-troff-me"),"mesh".__minus_gt("model/mesh"),"mid".__minus_gt("audio/midi"),"midi".__minus_gt("audio/midi"),"mif".__minus_gt("application/x-mif"),"mm".__minus_gt("application/x-freemind"),"mmd".__minus_gt("chemical/x-macromodel-input"),"mmf".__minus_gt("application/vnd.smaf"),"mml".__minus_gt("text/mathml"),"mmod".__minus_gt("chemical/x-macromodel-input"),"mng".__minus_gt("video/x-mng"),"moc".__minus_gt("text/x-moc"),"mol".__minus_gt("chemical/x-mdl-molfile"),"mol2".__minus_gt("chemical/x-mol2"),"moo".__minus_gt("chemical/x-mopac-out"),"mop".__minus_gt("chemical/x-mopac-input"),"mopcrt".__minus_gt("chemical/x-mopac-input"),"mov".__minus_gt("video/quicktime"),"movie".__minus_gt("video/x-sgi-movie"),"mp2".__minus_gt("audio/mpeg"),"mp3".__minus_gt("audio/mpeg"),"mp4".__minus_gt("video/mp4"),"mpc".__minus_gt("chemical/x-mopac-input"),"mpe".__minus_gt("video/mpeg"),"mpeg".__minus_gt("video/mpeg"),"mpega".__minus_gt("audio/mpeg"),"mpg".__minus_gt("video/mpeg"),"mpga".__minus_gt("audio/mpeg"),"ms".__minus_gt("application/x-troff-ms"),"msh".__minus_gt("model/mesh"),"msi".__minus_gt("application/x-msi"),"mvb".__minus_gt("chemical/x-mopac-vib"),"mxu".__minus_gt("video/vnd.mpegurl"),"nb".__minus_gt("application/mathematica"),"nc".__minus_gt("application/x-netcdf"),"nwc".__minus_gt("application/x-nwc"),"o".__minus_gt("application/x-object"),"oda".__minus_gt("application/oda"),"odb".__minus_gt("application/vnd.oasis.opendocument.database"),"odc".__minus_gt("application/vnd.oasis.opendocument.chart"),"odf".__minus_gt("application/vnd.oasis.opendocument.formula"),"odg".__minus_gt("application/vnd.oasis.opendocument.graphics"),"odi".__minus_gt("application/vnd.oasis.opendocument.image"),"odm".__minus_gt("application/vnd.oasis.opendocument.text-master"),"odp".__minus_gt("application/vnd.oasis.opendocument.presentation"),"ods".__minus_gt("application/vnd.oasis.opendocument.spreadsheet"),"odt".__minus_gt("application/vnd.oasis.opendocument.text"),"ogg".__minus_gt("application/ogg"),"old".__minus_gt("application/x-trash"),"oth".__minus_gt("application/vnd.oasis.opendocument.text-web"),"oza".__minus_gt("application/x-oz-application"),"p".__minus_gt("text/x-pascal"),"p7r".__minus_gt("application/x-pkcs7-certreqresp"),"pac".__minus_gt("application/x-ns-proxy-autoconfig"),"pas".__minus_gt("text/x-pascal"),"pat".__minus_gt("image/x-coreldrawpattern"),"pbm".__minus_gt("image/x-portable-bitmap"),"pcf".__minus_gt("application/x-font"),"pcf.Z".__minus_gt("application/x-font"),"pcx".__minus_gt("image/pcx"),"pdb".__minus_gt("chemical/x-pdb"),"pdf".__minus_gt("application/pdf"),"pfa".__minus_gt("application/x-font"),"pfb".__minus_gt("application/x-font"),"pgm".__minus_gt("image/x-portable-graymap"),"pgn".__minus_gt("application/x-chess-pgn"),"pgp".__minus_gt("application/pgp-signature"),"pk".__minus_gt("application/x-tex-pk"),"pl".__minus_gt("text/x-perl"),"pls".__minus_gt("audio/x-scpls"),"pm".__minus_gt("text/x-perl"),"png".__minus_gt("image/png"),"pnm".__minus_gt("image/x-portable-anymap"),"pot".__minus_gt("text/plain"),"ppm".__minus_gt("image/x-portable-pixmap"),"pps".__minus_gt("application/vnd.ms-powerpoint"),"ppt".__minus_gt("application/vnd.ms-powerpoint"),"prf".__minus_gt("application/pics-rules"),"prt".__minus_gt("chemical/x-ncbi-asn1-ascii"),"ps".__minus_gt("application/postscript"),"psd".__minus_gt("image/x-photoshop"),"psp".__minus_gt("text/x-psp"),"py".__minus_gt("text/x-python"),"pyc".__minus_gt("application/x-python-code"),"pyo".__minus_gt("application/x-python-code"),"qt".__minus_gt("video/quicktime"),"qtl".__minus_gt("application/x-quicktimeplayer"),"ra".__minus_gt("audio/x-realaudio"),"ram".__minus_gt("audio/x-pn-realaudio"),"rar".__minus_gt("application/rar"),"ras".__minus_gt("image/x-cmu-raster"),"rd".__minus_gt("chemical/x-mdl-rdfile"),"rdf".__minus_gt("application/rdf+xml"),"rgb".__minus_gt("image/x-rgb"),"rm".__minus_gt("audio/x-pn-realaudio"),"roff".__minus_gt("application/x-troff"),"ros".__minus_gt("chemical/x-rosdal"),"rpm".__minus_gt("application/x-redhat-package-manager"),"rss".__minus_gt("application/rss+xml"),"rtf".__minus_gt("text/rtf"),"rtx".__minus_gt("text/richtext"),"rxn".__minus_gt("chemical/x-mdl-rxnfile"),"sct".__minus_gt("text/scriptlet"),"sd".__minus_gt("chemical/x-mdl-sdfile"),"sd2".__minus_gt("audio/x-sd2"),"sda".__minus_gt("application/vnd.stardivision.draw"),"sdc".__minus_gt("application/vnd.stardivision.calc"),"sdd".__minus_gt("application/vnd.stardivision.impress"),"sdf".__minus_gt("chemical/x-mdl-sdfile"),"sdp".__minus_gt("application/vnd.stardivision.impress"),"sdw".__minus_gt("application/vnd.stardivision.writer"),"ser".__minus_gt("application/java-serialized-object"),"sgf".__minus_gt("application/x-go-sgf"),"sgl".__minus_gt("application/vnd.stardivision.writer-global"),"sh".__minus_gt("text/x-sh"),"shar".__minus_gt("application/x-shar"),"shtml".__minus_gt("text/html"),"sid".__minus_gt("audio/prs.sid"),"sik".__minus_gt("application/x-trash"),"silo".__minus_gt("model/mesh"),"sis".__minus_gt("application/vnd.symbian.install"),"sit".__minus_gt("application/x-stuffit"),"skd".__minus_gt("application/x-koan"),"skm".__minus_gt("application/x-koan"),"skp".__minus_gt("application/x-koan"),"skt".__minus_gt("application/x-koan"),"smf".__minus_gt("application/vnd.stardivision.math"),"smi".__minus_gt("application/smil"),"smil".__minus_gt("application/smil"),"snd".__minus_gt("audio/basic"),"spc".__minus_gt("chemical/x-galactic-spc"),"spl".__minus_gt("application/x-futuresplash"),"src".__minus_gt("application/x-wais-source"),"stc".__minus_gt("application/vnd.sun.xml.calc.template"),"std".__minus_gt("application/vnd.sun.xml.draw.template"),"sti".__minus_gt("application/vnd.sun.xml.impress.template"),"stl".__minus_gt("application/vnd.ms-pki.stl"),"stw".__minus_gt("application/vnd.sun.xml.writer.template"),"sty".__minus_gt("text/x-tex"),"sv4cpio".__minus_gt("application/x-sv4cpio"),"sv4crc".__minus_gt("application/x-sv4crc"),"svg".__minus_gt("image/svg+xml"),"svgz".__minus_gt("image/svg+xml"),"sw".__minus_gt("chemical/x-swissprot"),"swf".__minus_gt("application/x-shockwave-flash"),"swfl".__minus_gt("application/x-shockwave-flash"),"sxc".__minus_gt("application/vnd.sun.xml.calc"),"sxd".__minus_gt("application/vnd.sun.xml.draw"),"sxg".__minus_gt("application/vnd.sun.xml.writer.global"),"sxi".__minus_gt("application/vnd.sun.xml.impress"),"sxm".__minus_gt("application/vnd.sun.xml.math"),"sxw".__minus_gt("application/vnd.sun.xml.writer"),"t".__minus_gt("application/x-troff"),"tar".__minus_gt("application/x-tar"),"taz".__minus_gt("application/x-gtar"),"tcl".__minus_gt("text/x-tcl"),"tex".__minus_gt("text/x-tex"),"texi".__minus_gt("application/x-texinfo"),"texinfo".__minus_gt("application/x-texinfo"),"text".__minus_gt("text/plain"),"tgf".__minus_gt("chemical/x-mdl-tgf"),"tgz".__minus_gt("application/x-gtar"),"tif".__minus_gt("image/tiff"),"tiff".__minus_gt("image/tiff"),"tk".__minus_gt("text/x-tcl"),"tm".__minus_gt("text/texmacs"),"torrent".__minus_gt("application/x-bittorrent"),"tr".__minus_gt("application/x-troff"),"ts".__minus_gt("text/texmacs"),"tsp".__minus_gt("application/dsptype"),"tsv".__minus_gt("text/tab-separated-values"),"txt".__minus_gt("text/plain"),"udeb".__minus_gt("application/x-debian-package"),"uls".__minus_gt("text/iuls"),"ustar".__minus_gt("application/x-ustar"),"val".__minus_gt("chemical/x-ncbi-asn1-binary"),"vcd".__minus_gt("application/x-cdlink"),"vcf".__minus_gt("text/x-vcard"),"vcs".__minus_gt("text/x-vcalendar"),"vmd".__minus_gt("chemical/x-vmd"),"vms".__minus_gt("chemical/x-vamas-iso14976"),"vor".__minus_gt("application/vnd.stardivision.writer"),"vrm".__minus_gt("x-world/x-vrml"),"vrml".__minus_gt("x-world/x-vrml"),"vsd".__minus_gt("application/vnd.visio"),"wad".__minus_gt("application/x-doom"),"wav".__minus_gt("audio/x-wav"),"wax".__minus_gt("audio/x-ms-wax"),"wbmp".__minus_gt("image/vnd.wap.wbmp"),"wbxml".__minus_gt("application/vnd.wap.wbxml"),"wk".__minus_gt("application/x-123"),"wm".__minus_gt("video/x-ms-wm"),"wma".__minus_gt("audio/x-ms-wma"),"wmd".__minus_gt("application/x-ms-wmd"),"wml".__minus_gt("text/vnd.wap.wml"),"wmlc".__minus_gt("application/vnd.wap.wmlc"),"wmls".__minus_gt("text/vnd.wap.wmlscript"),"wmlsc".__minus_gt("application/vnd.wap.wmlscriptc"),"wmv".__minus_gt("video/x-ms-wmv"),"wmx".__minus_gt("video/x-ms-wmx"),"wmz".__minus_gt("application/x-ms-wmz"),"wp5".__minus_gt("application/wordperfect5.1"),"wpd".__minus_gt("application/wordperfect"),"wrl".__minus_gt("x-world/x-vrml"),"wsc".__minus_gt("text/scriptlet"),"wvx".__minus_gt("video/x-ms-wvx"),"wz".__minus_gt("application/x-wingz"),"xbm".__minus_gt("image/x-xbitmap"),"xcf".__minus_gt("application/x-xcf"),"xht".__minus_gt("application/xhtml+xml"),"xhtml".__minus_gt("application/xhtml+xml"),"xlb".__minus_gt("application/vnd.ms-excel"),"xls".__minus_gt("application/vnd.ms-excel"),"xlt".__minus_gt("application/vnd.ms-excel"),"xml".__minus_gt("application/xml"),"xpi".__minus_gt("application/x-xpinstall"),"xpm".__minus_gt("image/x-xpixmap"),"xsl".__minus_gt("application/xml"),"xtel".__minus_gt("chemical/x-xtel"),"xul".__minus_gt("application/vnd.mozilla.xul+xml"),"xwd".__minus_gt("image/x-xwindowdump"),"xyz".__minus_gt("chemical/x-xyz"),"zip".__minus_gt("application/zip"),"zmt".__minus_gt("chemical/x-mopac-input"),"~".__minus_gt("application/x-trash")]); return $1; }, function($ctx1) {$ctx1.fill(self,"defaultMimeTypes",{},smalltalk.FileServer.klass)})}, args: [], source: "defaultMimeTypes\x0a\x09^ #{\x0a\x09\x09'%' -> 'application/x-trash'.\x0a\x09\x09'323' -> 'text/h323'.\x0a\x09\x09'abw' -> 'application/x-abiword'.\x0a\x09\x09'ai' -> 'application/postscript'.\x0a\x09\x09'aif' -> 'audio/x-aiff'.\x0a\x09\x09'aifc' -> 'audio/x-aiff'.\x0a\x09\x09'aiff' -> 'audio/x-aiff'.\x0a\x09\x09'alc' -> 'chemical/x-alchemy'.\x0a\x09\x09'art' -> 'image/x-jg'.\x0a\x09\x09'asc' -> 'text/plain'.\x0a\x09\x09'asf' -> 'video/x-ms-asf'.\x0a\x09\x09'asn' -> 'chemical/x-ncbi-asn1-spec'.\x0a\x09\x09'aso' -> 'chemical/x-ncbi-asn1-binary'.\x0a\x09\x09'asx' -> 'video/x-ms-asf'.\x0a\x09\x09'au' -> 'audio/basic'.\x0a\x09\x09'avi' -> 'video/x-msvideo'.\x0a\x09\x09'b' -> 'chemical/x-molconn-Z'.\x0a\x09\x09'bak' -> 'application/x-trash'.\x0a\x09\x09'bat' -> 'application/x-msdos-program'.\x0a\x09\x09'bcpio' -> 'application/x-bcpio'.\x0a\x09\x09'bib' -> 'text/x-bibtex'.\x0a\x09\x09'bin' -> 'application/octet-stream'.\x0a\x09\x09'bmp' -> 'image/x-ms-bmp'.\x0a\x09\x09'book' -> 'application/x-maker'.\x0a\x09\x09'bsd' -> 'chemical/x-crossfire'.\x0a\x09\x09'c' -> 'text/x-csrc'.\x0a\x09\x09'c++' -> 'text/x-c++src'.\x0a\x09\x09'c3d' -> 'chemical/x-chem3d'.\x0a\x09\x09'cac' -> 'chemical/x-cache'.\x0a\x09\x09'cache' -> 'chemical/x-cache'.\x0a\x09\x09'cascii' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'cat' -> 'application/vnd.ms-pki.seccat'.\x0a\x09\x09'cbin' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'cc' -> 'text/x-c++src'.\x0a\x09\x09'cdf' -> 'application/x-cdf'.\x0a\x09\x09'cdr' -> 'image/x-coreldraw'.\x0a\x09\x09'cdt' -> 'image/x-coreldrawtemplate'.\x0a\x09\x09'cdx' -> 'chemical/x-cdx'.\x0a\x09\x09'cdy' -> 'application/vnd.cinderella'.\x0a\x09\x09'cef' -> 'chemical/x-cxf'.\x0a\x09\x09'cer' -> 'chemical/x-cerius'.\x0a\x09\x09'chm' -> 'chemical/x-chemdraw'.\x0a\x09\x09'chrt' -> 'application/x-kchart'.\x0a\x09\x09'cif' -> 'chemical/x-cif'.\x0a\x09\x09'class' -> 'application/java-vm'.\x0a\x09\x09'cls' -> 'text/x-tex'.\x0a\x09\x09'cmdf' -> 'chemical/x-cmdf'.\x0a\x09\x09'cml' -> 'chemical/x-cml'.\x0a\x09\x09'cod' -> 'application/vnd.rim.cod'.\x0a\x09\x09'com' -> 'application/x-msdos-program'.\x0a\x09\x09'cpa' -> 'chemical/x-compass'.\x0a\x09\x09'cpio' -> 'application/x-cpio'.\x0a\x09\x09'cpp' -> 'text/x-c++src'.\x0a\x09\x09'cpt' -> 'image/x-corelphotopaint'.\x0a\x09\x09'crl' -> 'application/x-pkcs7-crl'.\x0a\x09\x09'crt' -> 'application/x-x509-ca-cert'.\x0a\x09\x09'csf' -> 'chemical/x-cache-csf'.\x0a\x09\x09'csh' -> 'text/x-csh'.\x0a\x09\x09'csm' -> 'chemical/x-csml'.\x0a\x09\x09'csml' -> 'chemical/x-csml'.\x0a\x09\x09'css' -> 'text/css'.\x0a\x09\x09'csv' -> 'text/comma-separated-values'.\x0a\x09\x09'ctab' -> 'chemical/x-cactvs-binary'.\x0a\x09\x09'ctx' -> 'chemical/x-ctx'.\x0a\x09\x09'cu' -> 'application/cu-seeme'.\x0a\x09\x09'cub' -> 'chemical/x-gaussian-cube'.\x0a\x09\x09'cxf' -> 'chemical/x-cxf'.\x0a\x09\x09'cxx' -> 'text/x-c++src'.\x0a\x09\x09'dat' -> 'chemical/x-mopac-input'.\x0a\x09\x09'dcr' -> 'application/x-director'.\x0a\x09\x09'deb' -> 'application/x-debian-package'.\x0a\x09\x09'dif' -> 'video/dv'.\x0a\x09\x09'diff' -> 'text/plain'.\x0a\x09\x09'dir' -> 'application/x-director'.\x0a\x09\x09'djv' -> 'image/vnd.djvu'.\x0a\x09\x09'djvu' -> 'image/vnd.djvu'.\x0a\x09\x09'dl' -> 'video/dl'.\x0a\x09\x09'dll' -> 'application/x-msdos-program'.\x0a\x09\x09'dmg' -> 'application/x-apple-diskimage'.\x0a\x09\x09'dms' -> 'application/x-dms'.\x0a\x09\x09'doc' -> 'application/msword'.\x0a\x09\x09'dot' -> 'application/msword'.\x0a\x09\x09'dv' -> 'video/dv'.\x0a\x09\x09'dvi' -> 'application/x-dvi'.\x0a\x09\x09'dx' -> 'chemical/x-jcamp-dx'.\x0a\x09\x09'dxr' -> 'application/x-director'.\x0a\x09\x09'emb' -> 'chemical/x-embl-dl-nucleotide'.\x0a\x09\x09'embl' -> 'chemical/x-embl-dl-nucleotide'.\x0a\x09\x09'ent' -> 'chemical/x-pdb'.\x0a\x09\x09'eps' -> 'application/postscript'.\x0a\x09\x09'etx' -> 'text/x-setext'.\x0a\x09\x09'exe' -> 'application/x-msdos-program'.\x0a\x09\x09'ez' -> 'application/andrew-inset'.\x0a\x09\x09'fb' -> 'application/x-maker'.\x0a\x09\x09'fbdoc' -> 'application/x-maker'.\x0a\x09\x09'fch' -> 'chemical/x-gaussian-checkpoint'.\x0a\x09\x09'fchk' -> 'chemical/x-gaussian-checkpoint'.\x0a\x09\x09'fig' -> 'application/x-xfig'.\x0a\x09\x09'flac' -> 'application/x-flac'.\x0a\x09\x09'fli' -> 'video/fli'.\x0a\x09\x09'fm' -> 'application/x-maker'.\x0a\x09\x09'frame' -> 'application/x-maker'.\x0a\x09\x09'frm' -> 'application/x-maker'.\x0a\x09\x09'gal' -> 'chemical/x-gaussian-log'.\x0a\x09\x09'gam' -> 'chemical/x-gamess-input'.\x0a\x09\x09'gamin' -> 'chemical/x-gamess-input'.\x0a\x09\x09'gau' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gcd' -> 'text/x-pcs-gcd'.\x0a\x09\x09'gcf' -> 'application/x-graphing-calculator'.\x0a\x09\x09'gcg' -> 'chemical/x-gcg8-sequence'.\x0a\x09\x09'gen' -> 'chemical/x-genbank'.\x0a\x09\x09'gf' -> 'application/x-tex-gf'.\x0a\x09\x09'gif' -> 'image/gif'.\x0a\x09\x09'gjc' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gjf' -> 'chemical/x-gaussian-input'.\x0a\x09\x09'gl' -> 'video/gl'.\x0a\x09\x09'gnumeric' -> 'application/x-gnumeric'.\x0a\x09\x09'gpt' -> 'chemical/x-mopac-graph'.\x0a\x09\x09'gsf' -> 'application/x-font'.\x0a\x09\x09'gsm' -> 'audio/x-gsm'.\x0a\x09\x09'gtar' -> 'application/x-gtar'.\x0a\x09\x09'h' -> 'text/x-chdr'.\x0a\x09\x09'h++' -> 'text/x-c++hdr'.\x0a\x09\x09'hdf' -> 'application/x-hdf'.\x0a\x09\x09'hh' -> 'text/x-c++hdr'.\x0a\x09\x09'hin' -> 'chemical/x-hin'.\x0a\x09\x09'hpp' -> 'text/x-c++hdr'.\x0a\x09\x09'hqx' -> 'application/mac-binhex40'.\x0a\x09\x09'hs' -> 'text/x-haskell'.\x0a\x09\x09'hta' -> 'application/hta'.\x0a\x09\x09'htc' -> 'text/x-component'.\x0a\x09\x09'htm' -> 'text/html'.\x0a\x09\x09'html' -> 'text/html'.\x0a\x09\x09'hxx' -> 'text/x-c++hdr'.\x0a\x09\x09'ica' -> 'application/x-ica'.\x0a\x09\x09'ice' -> 'x-conference/x-cooltalk'.\x0a\x09\x09'ico' -> 'image/x-icon'.\x0a\x09\x09'ics' -> 'text/calendar'.\x0a\x09\x09'icz' -> 'text/calendar'.\x0a\x09\x09'ief' -> 'image/ief'.\x0a\x09\x09'iges' -> 'model/iges'.\x0a\x09\x09'igs' -> 'model/iges'.\x0a\x09\x09'iii' -> 'application/x-iphone'.\x0a\x09\x09'inp' -> 'chemical/x-gamess-input'.\x0a\x09\x09'ins' -> 'application/x-internet-signup'.\x0a\x09\x09'iso' -> 'application/x-iso9660-image'.\x0a\x09\x09'isp' -> 'application/x-internet-signup'.\x0a\x09\x09'ist' -> 'chemical/x-isostar'.\x0a\x09\x09'istr' -> 'chemical/x-isostar'.\x0a\x09\x09'jad' -> 'text/vnd.sun.j2me.app-descriptor'.\x0a\x09\x09'jar' -> 'application/java-archive'.\x0a\x09\x09'java' -> 'text/x-java'.\x0a\x09\x09'jdx' -> 'chemical/x-jcamp-dx'.\x0a\x09\x09'jmz' -> 'application/x-jmol'.\x0a\x09\x09'jng' -> 'image/x-jng'.\x0a\x09\x09'jnlp' -> 'application/x-java-jnlp-file'.\x0a\x09\x09'jpe' -> 'image/jpeg'.\x0a\x09\x09'jpeg' -> 'image/jpeg'.\x0a\x09\x09'jpg' -> 'image/jpeg'.\x0a\x09\x09'js' -> 'application/javascript'.\x0a\x09\x09'kar' -> 'audio/midi'.\x0a\x09\x09'key' -> 'application/pgp-keys'.\x0a\x09\x09'kil' -> 'application/x-killustrator'.\x0a\x09\x09'kin' -> 'chemical/x-kinemage'.\x0a\x09\x09'kpr' -> 'application/x-kpresenter'.\x0a\x09\x09'kpt' -> 'application/x-kpresenter'.\x0a\x09\x09'ksp' -> 'application/x-kspread'.\x0a\x09\x09'kwd' -> 'application/x-kword'.\x0a\x09\x09'kwt' -> 'application/x-kword'.\x0a\x09\x09'latex' -> 'application/x-latex'.\x0a\x09\x09'lha' -> 'application/x-lha'.\x0a\x09\x09'lhs' -> 'text/x-literate-haskell'.\x0a\x09\x09'lsf' -> 'video/x-la-asf'.\x0a\x09\x09'lsx' -> 'video/x-la-asf'.\x0a\x09\x09'ltx' -> 'text/x-tex'.\x0a\x09\x09'lzh' -> 'application/x-lzh'.\x0a\x09\x09'lzx' -> 'application/x-lzx'.\x0a\x09\x09'm3u' -> 'audio/x-mpegurl'.\x0a\x09\x09'm4a' -> 'audio/mpeg'.\x0a\x09\x09'maker' -> 'application/x-maker'.\x0a\x09\x09'man' -> 'application/x-troff-man'.\x0a\x09\x09'mcif' -> 'chemical/x-mmcif'.\x0a\x09\x09'mcm' -> 'chemical/x-macmolecule'.\x0a\x09\x09'mdb' -> 'application/msaccess'.\x0a\x09\x09'me' -> 'application/x-troff-me'.\x0a\x09\x09'mesh' -> 'model/mesh'.\x0a\x09\x09'mid' -> 'audio/midi'.\x0a\x09\x09'midi' -> 'audio/midi'.\x0a\x09\x09'mif' -> 'application/x-mif'.\x0a\x09\x09'mm' -> 'application/x-freemind'.\x0a\x09\x09'mmd' -> 'chemical/x-macromodel-input'.\x0a\x09\x09'mmf' -> 'application/vnd.smaf'.\x0a\x09\x09'mml' -> 'text/mathml'.\x0a\x09\x09'mmod' -> 'chemical/x-macromodel-input'.\x0a\x09\x09'mng' -> 'video/x-mng'.\x0a\x09\x09'moc' -> 'text/x-moc'.\x0a\x09\x09'mol' -> 'chemical/x-mdl-molfile'.\x0a\x09\x09'mol2' -> 'chemical/x-mol2'.\x0a\x09\x09'moo' -> 'chemical/x-mopac-out'.\x0a\x09\x09'mop' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mopcrt' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mov' -> 'video/quicktime'.\x0a\x09\x09'movie' -> 'video/x-sgi-movie'.\x0a\x09\x09'mp2' -> 'audio/mpeg'.\x0a\x09\x09'mp3' -> 'audio/mpeg'.\x0a\x09\x09'mp4' -> 'video/mp4'.\x0a\x09\x09'mpc' -> 'chemical/x-mopac-input'.\x0a\x09\x09'mpe' -> 'video/mpeg'.\x0a\x09\x09'mpeg' -> 'video/mpeg'.\x0a\x09\x09'mpega' -> 'audio/mpeg'.\x0a\x09\x09'mpg' -> 'video/mpeg'.\x0a\x09\x09'mpga' -> 'audio/mpeg'.\x0a\x09\x09'ms' -> 'application/x-troff-ms'.\x0a\x09\x09'msh' -> 'model/mesh'.\x0a\x09\x09'msi' -> 'application/x-msi'.\x0a\x09\x09'mvb' -> 'chemical/x-mopac-vib'.\x0a\x09\x09'mxu' -> 'video/vnd.mpegurl'.\x0a\x09\x09'nb' -> 'application/mathematica'.\x0a\x09\x09'nc' -> 'application/x-netcdf'.\x0a\x09\x09'nwc' -> 'application/x-nwc'.\x0a\x09\x09'o' -> 'application/x-object'.\x0a\x09\x09'oda' -> 'application/oda'.\x0a\x09\x09'odb' -> 'application/vnd.oasis.opendocument.database'.\x0a\x09\x09'odc' -> 'application/vnd.oasis.opendocument.chart'.\x0a\x09\x09'odf' -> 'application/vnd.oasis.opendocument.formula'.\x0a\x09\x09'odg' -> 'application/vnd.oasis.opendocument.graphics'.\x0a\x09\x09'odi' -> 'application/vnd.oasis.opendocument.image'.\x0a\x09\x09'odm' -> 'application/vnd.oasis.opendocument.text-master'.\x0a\x09\x09'odp' -> 'application/vnd.oasis.opendocument.presentation'.\x0a\x09\x09'ods' -> 'application/vnd.oasis.opendocument.spreadsheet'.\x0a\x09\x09'odt' -> 'application/vnd.oasis.opendocument.text'.\x0a\x09\x09'ogg' -> 'application/ogg'.\x0a\x09\x09'old' -> 'application/x-trash'.\x0a\x09\x09'oth' -> 'application/vnd.oasis.opendocument.text-web'.\x0a\x09\x09'oza' -> 'application/x-oz-application'.\x0a\x09\x09'p' -> 'text/x-pascal'.\x0a\x09\x09'p7r' -> 'application/x-pkcs7-certreqresp'.\x0a\x09\x09'pac' -> 'application/x-ns-proxy-autoconfig'.\x0a\x09\x09'pas' -> 'text/x-pascal'.\x0a\x09\x09'pat' -> 'image/x-coreldrawpattern'.\x0a\x09\x09'pbm' -> 'image/x-portable-bitmap'.\x0a\x09\x09'pcf' -> 'application/x-font'.\x0a\x09\x09'pcf.Z' -> 'application/x-font'.\x0a\x09\x09'pcx' -> 'image/pcx'.\x0a\x09\x09'pdb' -> 'chemical/x-pdb'.\x0a\x09\x09'pdf' -> 'application/pdf'.\x0a\x09\x09'pfa' -> 'application/x-font'.\x0a\x09\x09'pfb' -> 'application/x-font'.\x0a\x09\x09'pgm' -> 'image/x-portable-graymap'.\x0a\x09\x09'pgn' -> 'application/x-chess-pgn'.\x0a\x09\x09'pgp' -> 'application/pgp-signature'.\x0a\x09\x09'pk' -> 'application/x-tex-pk'.\x0a\x09\x09'pl' -> 'text/x-perl'.\x0a\x09\x09'pls' -> 'audio/x-scpls'.\x0a\x09\x09'pm' -> 'text/x-perl'.\x0a\x09\x09'png' -> 'image/png'.\x0a\x09\x09'pnm' -> 'image/x-portable-anymap'.\x0a\x09\x09'pot' -> 'text/plain'.\x0a\x09\x09'ppm' -> 'image/x-portable-pixmap'.\x0a\x09\x09'pps' -> 'application/vnd.ms-powerpoint'.\x0a\x09\x09'ppt' -> 'application/vnd.ms-powerpoint'.\x0a\x09\x09'prf' -> 'application/pics-rules'.\x0a\x09\x09'prt' -> 'chemical/x-ncbi-asn1-ascii'.\x0a\x09\x09'ps' -> 'application/postscript'.\x0a\x09\x09'psd' -> 'image/x-photoshop'.\x0a\x09\x09'psp' -> 'text/x-psp'.\x0a\x09\x09'py' -> 'text/x-python'.\x0a\x09\x09'pyc' -> 'application/x-python-code'.\x0a\x09\x09'pyo' -> 'application/x-python-code'.\x0a\x09\x09'qt' -> 'video/quicktime'.\x0a\x09\x09'qtl' -> 'application/x-quicktimeplayer'.\x0a\x09\x09'ra' -> 'audio/x-realaudio'.\x0a\x09\x09'ram' -> 'audio/x-pn-realaudio'.\x0a\x09\x09'rar' -> 'application/rar'.\x0a\x09\x09'ras' -> 'image/x-cmu-raster'.\x0a\x09\x09'rd' -> 'chemical/x-mdl-rdfile'.\x0a\x09\x09'rdf' -> 'application/rdf+xml'.\x0a\x09\x09'rgb' -> 'image/x-rgb'.\x0a\x09\x09'rm' -> 'audio/x-pn-realaudio'.\x0a\x09\x09'roff' -> 'application/x-troff'.\x0a\x09\x09'ros' -> 'chemical/x-rosdal'.\x0a\x09\x09'rpm' -> 'application/x-redhat-package-manager'.\x0a\x09\x09'rss' -> 'application/rss+xml'.\x0a\x09\x09'rtf' -> 'text/rtf'.\x0a\x09\x09'rtx' -> 'text/richtext'.\x0a\x09\x09'rxn' -> 'chemical/x-mdl-rxnfile'.\x0a\x09\x09'sct' -> 'text/scriptlet'.\x0a\x09\x09'sd' -> 'chemical/x-mdl-sdfile'.\x0a\x09\x09'sd2' -> 'audio/x-sd2'.\x0a\x09\x09'sda' -> 'application/vnd.stardivision.draw'.\x0a\x09\x09'sdc' -> 'application/vnd.stardivision.calc'.\x0a\x09\x09'sdd' -> 'application/vnd.stardivision.impress'.\x0a\x09\x09'sdf' -> 'chemical/x-mdl-sdfile'.\x0a\x09\x09'sdp' -> 'application/vnd.stardivision.impress'.\x0a\x09\x09'sdw' -> 'application/vnd.stardivision.writer'.\x0a\x09\x09'ser' -> 'application/java-serialized-object'.\x0a\x09\x09'sgf' -> 'application/x-go-sgf'.\x0a\x09\x09'sgl' -> 'application/vnd.stardivision.writer-global'.\x0a\x09\x09'sh' -> 'text/x-sh'.\x0a\x09\x09'shar' -> 'application/x-shar'.\x0a\x09\x09'shtml' -> 'text/html'.\x0a\x09\x09'sid' -> 'audio/prs.sid'.\x0a\x09\x09'sik' -> 'application/x-trash'.\x0a\x09\x09'silo' -> 'model/mesh'.\x0a\x09\x09'sis' -> 'application/vnd.symbian.install'.\x0a\x09\x09'sit' -> 'application/x-stuffit'.\x0a\x09\x09'skd' -> 'application/x-koan'.\x0a\x09\x09'skm' -> 'application/x-koan'.\x0a\x09\x09'skp' -> 'application/x-koan'.\x0a\x09\x09'skt' -> 'application/x-koan'.\x0a\x09\x09'smf' -> 'application/vnd.stardivision.math'.\x0a\x09\x09'smi' -> 'application/smil'.\x0a\x09\x09'smil' -> 'application/smil'.\x0a\x09\x09'snd' -> 'audio/basic'.\x0a\x09\x09'spc' -> 'chemical/x-galactic-spc'.\x0a\x09\x09'spl' -> 'application/x-futuresplash'.\x0a\x09\x09'src' -> 'application/x-wais-source'.\x0a\x09\x09'stc' -> 'application/vnd.sun.xml.calc.template'.\x0a\x09\x09'std' -> 'application/vnd.sun.xml.draw.template'.\x0a\x09\x09'sti' -> 'application/vnd.sun.xml.impress.template'.\x0a\x09\x09'stl' -> 'application/vnd.ms-pki.stl'.\x0a\x09\x09'stw' -> 'application/vnd.sun.xml.writer.template'.\x0a\x09\x09'sty' -> 'text/x-tex'.\x0a\x09\x09'sv4cpio' -> 'application/x-sv4cpio'.\x0a\x09\x09'sv4crc' -> 'application/x-sv4crc'.\x0a\x09\x09'svg' -> 'image/svg+xml'.\x0a\x09\x09'svgz' -> 'image/svg+xml'.\x0a\x09\x09'sw' -> 'chemical/x-swissprot'.\x0a\x09\x09'swf' -> 'application/x-shockwave-flash'.\x0a\x09\x09'swfl' -> 'application/x-shockwave-flash'.\x0a\x09\x09'sxc' -> 'application/vnd.sun.xml.calc'.\x0a\x09\x09'sxd' -> 'application/vnd.sun.xml.draw'.\x0a\x09\x09'sxg' -> 'application/vnd.sun.xml.writer.global'.\x0a\x09\x09'sxi' -> 'application/vnd.sun.xml.impress'.\x0a\x09\x09'sxm' -> 'application/vnd.sun.xml.math'.\x0a\x09\x09'sxw' -> 'application/vnd.sun.xml.writer'.\x0a\x09\x09't' -> 'application/x-troff'.\x0a\x09\x09'tar' -> 'application/x-tar'.\x0a\x09\x09'taz' -> 'application/x-gtar'.\x0a\x09\x09'tcl' -> 'text/x-tcl'.\x0a\x09\x09'tex' -> 'text/x-tex'.\x0a\x09\x09'texi' -> 'application/x-texinfo'.\x0a\x09\x09'texinfo' -> 'application/x-texinfo'.\x0a\x09\x09'text' -> 'text/plain'.\x0a\x09\x09'tgf' -> 'chemical/x-mdl-tgf'.\x0a\x09\x09'tgz' -> 'application/x-gtar'.\x0a\x09\x09'tif' -> 'image/tiff'.\x0a\x09\x09'tiff' -> 'image/tiff'.\x0a\x09\x09'tk' -> 'text/x-tcl'.\x0a\x09\x09'tm' -> 'text/texmacs'.\x0a\x09\x09'torrent' -> 'application/x-bittorrent'.\x0a\x09\x09'tr' -> 'application/x-troff'.\x0a\x09\x09'ts' -> 'text/texmacs'.\x0a\x09\x09'tsp' -> 'application/dsptype'.\x0a\x09\x09'tsv' -> 'text/tab-separated-values'.\x0a\x09\x09'txt' -> 'text/plain'.\x0a\x09\x09'udeb' -> 'application/x-debian-package'.\x0a\x09\x09'uls' -> 'text/iuls'.\x0a\x09\x09'ustar' -> 'application/x-ustar'.\x0a\x09\x09'val' -> 'chemical/x-ncbi-asn1-binary'.\x0a\x09\x09'vcd' -> 'application/x-cdlink'.\x0a\x09\x09'vcf' -> 'text/x-vcard'.\x0a\x09\x09'vcs' -> 'text/x-vcalendar'.\x0a\x09\x09'vmd' -> 'chemical/x-vmd'.\x0a\x09\x09'vms' -> 'chemical/x-vamas-iso14976'.\x0a\x09\x09'vor' -> 'application/vnd.stardivision.writer'.\x0a\x09\x09'vrm' -> 'x-world/x-vrml'.\x0a\x09\x09'vrml' -> 'x-world/x-vrml'.\x0a\x09\x09'vsd' -> 'application/vnd.visio'.\x0a\x09\x09'wad' -> 'application/x-doom'.\x0a\x09\x09'wav' -> 'audio/x-wav'.\x0a\x09\x09'wax' -> 'audio/x-ms-wax'.\x0a\x09\x09'wbmp' -> 'image/vnd.wap.wbmp'.\x0a\x09\x09'wbxml' -> 'application/vnd.wap.wbxml'.\x0a\x09\x09'wk' -> 'application/x-123'.\x0a\x09\x09'wm' -> 'video/x-ms-wm'.\x0a\x09\x09'wma' -> 'audio/x-ms-wma'.\x0a\x09\x09'wmd' -> 'application/x-ms-wmd'.\x0a\x09\x09'wml' -> 'text/vnd.wap.wml'.\x0a\x09\x09'wmlc' -> 'application/vnd.wap.wmlc'.\x0a\x09\x09'wmls' -> 'text/vnd.wap.wmlscript'.\x0a\x09\x09'wmlsc' -> 'application/vnd.wap.wmlscriptc'.\x0a\x09\x09'wmv' -> 'video/x-ms-wmv'.\x0a\x09\x09'wmx' -> 'video/x-ms-wmx'.\x0a\x09\x09'wmz' -> 'application/x-ms-wmz'.\x0a\x09\x09'wp5' -> 'application/wordperfect5.1'.\x0a\x09\x09'wpd' -> 'application/wordperfect'.\x0a\x09\x09'wrl' -> 'x-world/x-vrml'.\x0a\x09\x09'wsc' -> 'text/scriptlet'.\x0a\x09\x09'wvx' -> 'video/x-ms-wvx'.\x0a\x09\x09'wz' -> 'application/x-wingz'.\x0a\x09\x09'xbm' -> 'image/x-xbitmap'.\x0a\x09\x09'xcf' -> 'application/x-xcf'.\x0a\x09\x09'xht' -> 'application/xhtml+xml'.\x0a\x09\x09'xhtml' -> 'application/xhtml+xml'.\x0a\x09\x09'xlb' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xls' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xlt' -> 'application/vnd.ms-excel'.\x0a\x09\x09'xml' -> 'application/xml'.\x0a\x09\x09'xpi' -> 'application/x-xpinstall'.\x0a\x09\x09'xpm' -> 'image/x-xpixmap'.\x0a\x09\x09'xsl' -> 'application/xml'.\x0a\x09\x09'xtel' -> 'chemical/x-xtel'.\x0a\x09\x09'xul' -> 'application/vnd.mozilla.xul+xml'.\x0a\x09\x09'xwd' -> 'image/x-xwindowdump'.\x0a\x09\x09'xyz' -> 'chemical/x-xyz'.\x0a\x09\x09'zip' -> 'application/zip'.\x0a\x09\x09'zmt' -> 'chemical/x-mopac-input'.\x0a\x09\x09'~' -> 'application/x-trash'\x0a\x09}", messageSends: ["->"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "defaultPort", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return (4000); }, function($ctx1) {$ctx1.fill(self,"defaultPort",{},smalltalk.FileServer.klass)})}, args: [], source: "defaultPort\x0a\x09^4000", messageSends: [], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "main", category: 'initialization', fn: function (){ var self=this; var fileServer,args; function $FileServer(){return smalltalk.FileServer||(typeof FileServer=="undefined"?nil:FileServer)} return smalltalk.withContext(function($ctx1) { var $1,$2; var $early={}; try { args=_st(process)._argv(); _st(args)._removeFrom_to_((1),(3)); _st(args)._detect_ifNone_((function(each){ return smalltalk.withContext(function($ctx2) { $1=_st(each).__eq("--help"); if(smalltalk.assert($1)){ return _st($FileServer())._printHelp(); }; }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}),(function(){ return smalltalk.withContext(function($ctx2) { fileServer=_st($FileServer())._createServerWithArguments_(args); fileServer; $2=_st(fileServer)._start(); throw $early=[$2]; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return self} catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"main",{fileServer:fileServer,args:args},smalltalk.FileServer.klass)})}, args: [], source: "main\x0a\x09\x22Main entry point for Amber applications.\x0a\x09 Creates and starts a FileServer instance.\x22\x0a\x09| fileServer args |\x0a\x09args := process argv.\x0a\x09\x22Remove the first args which contain the path to the node executable and the script file.\x22\x0a\x09args removeFrom: 1 to: 3.\x0a\x0a\x09args detect: [ :each |\x0a\x09\x09(each = '--help') ifTrue: [FileServer printHelp]]\x0a\x09ifNone: [\x0a\x09\x09fileServer := FileServer createServerWithArguments: args.\x0a\x09\x09^fileServer start]", messageSends: ["argv", "removeFrom:to:", "detect:ifNone:", "ifTrue:", "printHelp", "=", "createServerWithArguments:", "start"], referencedClasses: ["FileServer"] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "mimeTypeFor:", category: 'accessing', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._mimeTypes())._at_ifAbsent_(_st(aString)._replace_with_(".*[\x5c.]",""),(function(){ return smalltalk.withContext(function($ctx2) { return "text/plain"; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"mimeTypeFor:",{aString:aString},smalltalk.FileServer.klass)})}, args: ["aString"], source: "mimeTypeFor: aString\x0a\x09^self mimeTypes at: (aString replace: '.*[\x5c.]' with: '') ifAbsent: ['text/plain']", messageSends: ["at:ifAbsent:", "replace:with:", "mimeTypes"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "mimeTypes", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=self["@mimeTypes"]; if(($receiver = $2) == nil || $receiver == undefined){ self["@mimeTypes"]=self._defaultMimeTypes(); $1=self["@mimeTypes"]; } else { $1=$2; }; return $1; }, function($ctx1) {$ctx1.fill(self,"mimeTypes",{},smalltalk.FileServer.klass)})}, args: [], source: "mimeTypes\x0a\x09^mimeTypes ifNil: [mimeTypes := self defaultMimeTypes]", messageSends: ["ifNil:", "defaultMimeTypes"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "printHelp", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(console)._log_("Available commandline options are:"); _st(console)._log_("--help"); _st(self._commandLineSwitches())._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(console)._log_(_st(each).__comma(" ")); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"printHelp",{},smalltalk.FileServer.klass)})}, args: [], source: "printHelp\x0a\x09console log: 'Available commandline options are:'.\x0a\x09console log: '--help'.\x0a\x09self commandLineSwitches do: [ :each |\x0a\x09\x09console log: each, ' ']", messageSends: ["log:", "do:", ",", "commandLineSwitches"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addMethod( smalltalk.method({ selector: "selectorForCommandLineSwitch:", category: 'accessing', fn: function (aSwitch){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(_st(aSwitch)._replace_with_("^--",""))._replace_with_("-[a-z]",(function(each){ return smalltalk.withContext(function($ctx2) { return _st(_st(each)._second())._asUppercase(); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}))).__comma(":"); return $1; }, function($ctx1) {$ctx1.fill(self,"selectorForCommandLineSwitch:",{aSwitch:aSwitch},smalltalk.FileServer.klass)})}, args: ["aSwitch"], source: "selectorForCommandLineSwitch: aSwitch\x0a\x09\x22Remove the trailing '--', add ':' at the end\x0a\x09 and replace all occurences of a lowercase letter preceded by a '-' with\x0a\x09 the Uppercase letter.\x0a\x09 Example: --fallback-page becomes fallbackPage:\x22\x0a\x09^((aSwitch replace: '^--' with: '')\x0a\x09\x09replace: '-[a-z]' with: [ :each | each second asUppercase ]), ':'", messageSends: [",", "replace:with:", "asUppercase", "second"], referencedClasses: [] }), smalltalk.FileServer.klass); smalltalk.addClass('Repl', smalltalk.Object, ['readline', 'interface', 'util', 'session', 'resultCount', 'commands'], 'AmberCli'); smalltalk.Repl.comment="I am a class representing a REPL (Read Evaluate Print Loop) and provide a command line interface to Amber Smalltalk.\x0aOn the prompt you can type Amber statements which will be evaluated after pressing .\x0aThe evaluation is comparable with executing a 'DoIt' in a workspace.\x0a\x0aMy runtime requirement is a functional Node.js executable with working Readline support."; smalltalk.addMethod( smalltalk.method({ selector: "addVariableNamed:to:", category: 'private', fn: function (aString,anObject){ var self=this; var newClass,newObject; return smalltalk.withContext(function($ctx1) { var $1; newClass=self._subclass_withVariable_(_st(anObject)._class(),aString); self._encapsulateVariable_withValue_in_(aString,anObject,newClass); newObject=_st(newClass)._new(); self._setPreviousVariablesFor_from_(newObject,anObject); $1=newObject; return $1; }, function($ctx1) {$ctx1.fill(self,"addVariableNamed:to:",{aString:aString,anObject:anObject,newClass:newClass,newObject:newObject},smalltalk.Repl)})}, args: ["aString", "anObject"], source: "addVariableNamed: aString to: anObject\x0a\x09| newClass newObject |\x0a\x09newClass := self subclass: anObject class withVariable: aString.\x0a\x09self encapsulateVariable: aString withValue: anObject in: newClass.\x0a\x09newObject := newClass new.\x0a\x09self setPreviousVariablesFor: newObject from: anObject.\x0a\x09^ newObject", messageSends: ["subclass:withVariable:", "class", "encapsulateVariable:withValue:in:", "new", "setPreviousVariablesFor:from:"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "assignNewVariable:do:", category: 'private', fn: function (buffer,aBlock){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$3,$5,$7,$6,$4,$1; $1=self._parseAssignment_do_(buffer,(function(name,expr){ var varName,value; return smalltalk.withContext(function($ctx2) { $2=name; if(($receiver = $2) == nil || $receiver == undefined){ varName=self._nextResultName(); } else { varName=$2; }; varName; self["@session"]=self._addVariableNamed_to_(varName,self["@session"]); self["@session"]; $3=self; $5=_st(varName).__comma(" := "); $7=expr; if(($receiver = $7) == nil || $receiver == undefined){ $6=buffer; } else { $6=$7; }; $4=_st($5).__comma($6); value=_st($3)._eval_on_($4,self["@session"]); value; return _st(aBlock)._value_value_(varName,value); }, function($ctx2) {$ctx2.fillBlock({name:name,expr:expr,varName:varName,value:value},$ctx1)})})); return $1; }, function($ctx1) {$ctx1.fill(self,"assignNewVariable:do:",{buffer:buffer,aBlock:aBlock},smalltalk.Repl)})}, args: ["buffer", "aBlock"], source: "assignNewVariable: buffer do: aBlock\x0a\x09\x22Assigns a new variable and calls the given block with the variable's name and value\x0a\x09 if buffer contains an assignment expression. If it doesn't the block is called with nil for\x0a\x09 both arguments.\x22\x0a\x09^ self parseAssignment: buffer do: [ :name :expr || varName value |\x0a\x09\x09varName := name ifNil: [self nextResultName].\x0a\x09\x09session := self addVariableNamed: varName to: session.\x0a\x09\x09value := self eval: varName, ' := ', (expr ifNil: [buffer]) on: session.\x0a\x09\x09aBlock value: varName value: value]", messageSends: ["parseAssignment:do:", "ifNil:", "nextResultName", "addVariableNamed:to:", "eval:on:", ",", "value:value:"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "clearScreen", category: 'private', fn: function (){ var self=this; var esc,cls; function $String(){return smalltalk.String||(typeof String=="undefined"?nil:String)} return smalltalk.withContext(function($ctx1) { esc=_st($String())._fromCharCode_((27)); cls=_st(_st(_st(esc).__comma("[2J")).__comma(esc)).__comma("[0;0f"); _st(_st(process)._stdout())._write_(cls); _st(self["@interface"])._prompt(); return self}, function($ctx1) {$ctx1.fill(self,"clearScreen",{esc:esc,cls:cls},smalltalk.Repl)})}, args: [], source: "clearScreen\x0a\x09| esc cls |\x0a\x09esc := String fromCharCode: 27.\x0a\x09cls := esc, '[2J', esc, '[0;0f'.\x0a\x09process stdout write: cls.\x0a\x09interface prompt", messageSends: ["fromCharCode:", ",", "write:", "stdout", "prompt"], referencedClasses: ["String"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "close", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(_st(process)._stdin())._destroy(); return self}, function($ctx1) {$ctx1.fill(self,"close",{},smalltalk.Repl)})}, args: [], source: "close\x0a\x09process stdin destroy", messageSends: ["destroy", "stdin"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "commands", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=self["@commands"]; return $1; }, function($ctx1) {$ctx1.fill(self,"commands",{},smalltalk.Repl)})}, args: [], source: "commands\x0a\x09^ commands", messageSends: [], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "createInterface", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; self["@interface"]=_st(self["@readline"])._createInterface_stdout_(_st(process)._stdin(),_st(process)._stdout()); _st(self["@interface"])._on_do_("line",(function(buffer){ return smalltalk.withContext(function($ctx2) { return self._processLine_(buffer); }, function($ctx2) {$ctx2.fillBlock({buffer:buffer},$ctx1)})})); _st(self["@interface"])._on_do_("close",(function(){ return smalltalk.withContext(function($ctx2) { return self._close(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); $1=self; _st($1)._printWelcome(); _st($1)._setupHotkeys(); $2=_st($1)._setPrompt(); _st(self["@interface"])._prompt(); return self}, function($ctx1) {$ctx1.fill(self,"createInterface",{},smalltalk.Repl)})}, args: [], source: "createInterface\x0a\x09interface := readline createInterface: process stdin stdout: process stdout.\x0a\x09interface on: 'line' do: [:buffer | self processLine: buffer].\x0a\x09interface on: 'close' do: [self close].\x0a\x09self printWelcome; setupHotkeys; setPrompt.\x0a\x09interface prompt", messageSends: ["createInterface:stdout:", "stdin", "stdout", "on:do:", "processLine:", "close", "printWelcome", "setupHotkeys", "setPrompt", "prompt"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "encapsulateVariable:withValue:in:", category: 'private', fn: function (aString,anObject,aClass){ var self=this; var compiler; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} return smalltalk.withContext(function($ctx1) { compiler=_st($Compiler())._new(); _st(compiler)._install_forClass_category_(_st(_st(_st(aString).__comma(": anObject ^ ")).__comma(aString)).__comma(" := anObject"),aClass,"session"); _st(compiler)._install_forClass_category_(_st(_st(aString).__comma(" ^ ")).__comma(aString),aClass,"session"); return self}, function($ctx1) {$ctx1.fill(self,"encapsulateVariable:withValue:in:",{aString:aString,anObject:anObject,aClass:aClass,compiler:compiler},smalltalk.Repl)})}, args: ["aString", "anObject", "aClass"], source: "encapsulateVariable: aString withValue: anObject in: aClass\x0a\x09\x22Add getter and setter for given variable to session.\x22\x0a\x09| compiler |\x0a\x09compiler := Compiler new.\x0a\x09compiler install: aString, ': anObject ^ ', aString, ' := anObject' forClass: aClass category: 'session'.\x0a\x09compiler install: aString, ' ^ ', aString forClass: aClass category: 'session'.", messageSends: ["new", "install:forClass:category:", ","], referencedClasses: ["Compiler"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "eval:", category: 'actions', fn: function (buffer){ var self=this; function $DoIt(){return smalltalk.DoIt||(typeof DoIt=="undefined"?nil:DoIt)} return smalltalk.withContext(function($ctx1) { var $1; $1=self._eval_on_(buffer,_st($DoIt())._new()); return $1; }, function($ctx1) {$ctx1.fill(self,"eval:",{buffer:buffer},smalltalk.Repl)})}, args: ["buffer"], source: "eval: buffer\x0a\x09^ self eval: buffer on: DoIt new.", messageSends: ["eval:on:", "new"], referencedClasses: ["DoIt"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "eval:on:", category: 'actions', fn: function (buffer,anObject){ var self=this; var result; function $Compiler(){return smalltalk.Compiler||(typeof Compiler=="undefined"?nil:Compiler)} function $ErrorHandler(){return smalltalk.ErrorHandler||(typeof ErrorHandler=="undefined"?nil:ErrorHandler)} return smalltalk.withContext(function($ctx1) { var $1,$2,$3; $1=_st(buffer)._isEmpty(); if(! smalltalk.assert($1)){ self._try_catch_((function(){ return smalltalk.withContext(function($ctx2) { result=_st(_st($Compiler())._new())._evaluateExpression_on_(buffer,anObject); return result; }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}),(function(e){ return smalltalk.withContext(function($ctx2) { $2=_st(e)._isSmalltalkError(); if(smalltalk.assert($2)){ return _st(_st($ErrorHandler())._new())._handleError_(e); } else { return _st(_st(process)._stdout())._write_(_st(e)._jsStack()); }; }, function($ctx2) {$ctx2.fillBlock({e:e},$ctx1)})})); }; $3=result; return $3; }, function($ctx1) {$ctx1.fill(self,"eval:on:",{buffer:buffer,anObject:anObject,result:result},smalltalk.Repl)})}, args: ["buffer", "anObject"], source: "eval: buffer on: anObject\x0a\x09| result |\x0a\x09buffer isEmpty ifFalse: [\x0a\x09\x09self try: [\x0a\x09\x09\x09result := Compiler new evaluateExpression: buffer on: anObject]\x0a\x09\x09catch: [:e |\x0a\x09\x09\x09e isSmalltalkError\x0a\x09\x09\x09 ifTrue: [ErrorHandler new handleError: e]\x0a\x09\x09\x09 ifFalse: [process stdout write: e jsStack]]].\x0a\x09^ result", messageSends: ["ifFalse:", "try:catch:", "evaluateExpression:on:", "new", "ifTrue:ifFalse:", "handleError:", "write:", "jsStack", "stdout", "isSmalltalkError", "isEmpty"], referencedClasses: ["Compiler", "ErrorHandler"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "executeCommand:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; var $early={}; try { _st(self._commands())._keysAndValuesDo_((function(names,cmd){ return smalltalk.withContext(function($ctx2) { $1=_st(names)._includes_(aString); if(smalltalk.assert($1)){ _st(cmd)._value(); throw $early=[true]; }; }, function($ctx2) {$ctx2.fillBlock({names:names,cmd:cmd},$ctx1)})})); return false; } catch(e) {if(e===$early)return e[0]; throw e} }, function($ctx1) {$ctx1.fill(self,"executeCommand:",{aString:aString},smalltalk.Repl)})}, args: ["aString"], source: "executeCommand: aString\x0a\x09\x22Tries to process the given string as a command. Returns true if it was a command, false if not.\x22\x0a\x09self commands keysAndValuesDo: [:names :cmd |\x0a\x09\x09(names includes: aString) ifTrue: [\x0a\x09\x09\x09cmd value.\x0a\x09\x09\x09^ true]].\x0a\x09^ false", messageSends: ["keysAndValuesDo:", "ifTrue:", "value", "includes:", "commands"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "initialize", category: 'initialization', fn: function (){ var self=this; function $DoIt(){return smalltalk.DoIt||(typeof DoIt=="undefined"?nil:DoIt)} return smalltalk.withContext(function($ctx1) { smalltalk.Repl.superclass.fn.prototype._initialize.apply(_st(self), []); self["@session"]=_st($DoIt())._new(); self["@readline"]=_st(require)._value_("readline"); self["@util"]=_st(require)._value_("util"); self._setupCommands(); return self}, function($ctx1) {$ctx1.fill(self,"initialize",{},smalltalk.Repl)})}, args: [], source: "initialize\x0a\x09super initialize.\x0a\x09session := DoIt new.\x0a\x09readline := require value: 'readline'.\x0a\x09util := require value: 'util'.\x0a\x09self setupCommands", messageSends: ["initialize", "new", "value:", "setupCommands"], referencedClasses: ["DoIt"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "instanceVariableNamesFor:", category: 'private', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(aClass)._superclass(); if(($receiver = $2) == nil || $receiver == undefined){ $1=_st(aClass)._instanceVariableNames(); } else { $1=_st(_st(aClass)._instanceVariableNames())._copyWithAll_(self._instanceVariableNamesFor_(_st(aClass)._superclass())); }; return $1; }, function($ctx1) {$ctx1.fill(self,"instanceVariableNamesFor:",{aClass:aClass},smalltalk.Repl)})}, args: ["aClass"], source: "instanceVariableNamesFor: aClass\x0a\x09\x22Yields all instance variable names for the given class, including inherited ones.\x22\x0a\x09^ aClass superclass\x0a\x09\x09ifNotNil: [\x0a\x09\x09\x09aClass instanceVariableNames copyWithAll: (self instanceVariableNamesFor: aClass superclass)]\x0a\x09\x09ifNil: [\x0a\x09\x09\x09aClass instanceVariableNames]", messageSends: ["ifNotNil:ifNil:", "copyWithAll:", "instanceVariableNamesFor:", "superclass", "instanceVariableNames"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "isIdentifier:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(aString)._match_("^[a-z_]\x5cw+$"._asRegexp()); return $1; }, function($ctx1) {$ctx1.fill(self,"isIdentifier:",{aString:aString},smalltalk.Repl)})}, args: ["aString"], source: "isIdentifier: aString\x0a\x09^ aString match: '^[a-z_]\x5cw+$' asRegexp", messageSends: ["match:", "asRegexp"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "isVariableDefined:", category: 'private', fn: function (aString){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(self._instanceVariableNamesFor_(_st(self["@session"])._class()))._includes_(aString); return $1; }, function($ctx1) {$ctx1.fill(self,"isVariableDefined:",{aString:aString},smalltalk.Repl)})}, args: ["aString"], source: "isVariableDefined: aString\x0a\x09^ (self instanceVariableNamesFor: session class) includes: aString", messageSends: ["includes:", "instanceVariableNamesFor:", "class"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "nextResultName", category: 'private', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1,$2; $1=self["@resultCount"]; if(($receiver = $1) == nil || $receiver == undefined){ self["@resultCount"]=(1); } else { self["@resultCount"]=_st(self["@resultCount"]).__plus((1)); }; $2="res".__comma(_st(self["@resultCount"])._asString()); return $2; }, function($ctx1) {$ctx1.fill(self,"nextResultName",{},smalltalk.Repl)})}, args: [], source: "nextResultName\x0a\x09resultCount := resultCount\x0a \x09ifNotNil: [resultCount + 1]\x0a \x09ifNil: [1].\x0a ^ 'res', resultCount asString", messageSends: ["ifNotNil:ifNil:", "+", ",", "asString"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "onKeyPress:", category: 'private', fn: function (key){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st(key)._ctrl())._and_((function(){ return smalltalk.withContext(function($ctx2) { return _st(_st(key)._name()).__eq("l"); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($1)){ self._clearScreen(); }; return self}, function($ctx1) {$ctx1.fill(self,"onKeyPress:",{key:key},smalltalk.Repl)})}, args: ["key"], source: "onKeyPress: key\x0a\x09(key ctrl and: [key name = 'l'])\x0a\x09\x09ifTrue: [self clearScreen]", messageSends: ["ifTrue:", "clearScreen", "and:", "=", "name", "ctrl"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "parseAssignment:do:", category: 'private', fn: function (aString,aBlock){ var self=this; var assignment; return smalltalk.withContext(function($ctx1) { var $2,$1; assignment=_st(_st(aString)._tokenize_(":="))._collect_((function(s){ return smalltalk.withContext(function($ctx2) { return _st(s)._trimBoth(); }, function($ctx2) {$ctx2.fillBlock({s:s},$ctx1)})})); $2=_st(_st(_st(assignment)._size()).__eq((2)))._and_((function(){ return smalltalk.withContext(function($ctx2) { return self._isIdentifier_(_st(assignment)._first()); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})); if(smalltalk.assert($2)){ $1=_st(aBlock)._value_value_(_st(assignment)._first(),_st(assignment)._last()); } else { $1=_st(aBlock)._value_value_(nil,nil); }; return $1; }, function($ctx1) {$ctx1.fill(self,"parseAssignment:do:",{aString:aString,aBlock:aBlock,assignment:assignment},smalltalk.Repl)})}, args: ["aString", "aBlock"], source: "parseAssignment: aString do: aBlock\x0a\x09\x22Assigns a new variable if the given string is an assignment expression. Calls the given block with name and value.\x0a\x09 If the string is not one no variable will be assigned and the block will be called with nil for both arguments.\x22\x0a\x09| assignment |\x0a\x09assignment := (aString tokenize: ':=') collect: [:s | s trimBoth].\x0a\x09^ (assignment size = 2 and: [self isIdentifier: assignment first])\x0a\x09\x09ifTrue: [aBlock value: assignment first value: assignment last]\x0a\x09\x09ifFalse: [aBlock value: nil value: nil]", messageSends: ["collect:", "trimBoth", "tokenize:", "ifTrue:ifFalse:", "value:value:", "first", "last", "and:", "isIdentifier:", "=", "size"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "presentResultNamed:withValue:", category: 'private', fn: function (varName,value){ var self=this; function $Transcript(){return smalltalk.Transcript||(typeof Transcript=="undefined"?nil:Transcript)} return smalltalk.withContext(function($ctx1) { var $1,$2; $1=$Transcript(); _st($1)._show_(_st(_st(_st(_st(varName).__comma(": ")).__comma(_st(_st(value)._class())._name())).__comma(" = ")).__comma(_st(value)._asString())); $2=_st($1)._cr(); _st(self["@interface"])._prompt(); return self}, function($ctx1) {$ctx1.fill(self,"presentResultNamed:withValue:",{varName:varName,value:value},smalltalk.Repl)})}, args: ["varName", "value"], source: "presentResultNamed: varName withValue: value\x0a\x09Transcript show: varName, ': ', value class name, ' = ', value asString; cr.\x0a\x09interface prompt", messageSends: ["show:", ",", "asString", "name", "class", "cr", "prompt"], referencedClasses: ["Transcript"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "printWelcome", category: 'private', fn: function (){ var self=this; function $Smalltalk(){return smalltalk.Smalltalk||(typeof Smalltalk=="undefined"?nil:Smalltalk)} function $Transcript(){return smalltalk.Transcript||(typeof Transcript=="undefined"?nil:Transcript)} return smalltalk.withContext(function($ctx1) { var $1,$2; _st($Transcript())._show_(_st(_st(_st("Welcome to Amber version ".__comma(_st(_st($Smalltalk())._current())._version())).__comma(" (NodeJS ")).__comma(_st(_st(process)._versions())._node())).__comma(").")); $1=$Transcript(); _st($1)._show_("Type :q to exit."); $2=_st($1)._cr(); return self}, function($ctx1) {$ctx1.fill(self,"printWelcome",{},smalltalk.Repl)})}, args: [], source: "printWelcome\x0a\x09Transcript show: 'Welcome to Amber version ', Smalltalk current version, ' (NodeJS ', process versions node, ').'.\x0a\x09Transcript show: 'Type :q to exit.'; cr.", messageSends: ["show:", ",", "node", "versions", "version", "current", "cr"], referencedClasses: ["Smalltalk", "Transcript"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "processLine:", category: 'private', fn: function (buffer){ var self=this; var show; return smalltalk.withContext(function($ctx1) { var $1,$2; show=(function(varName,value){ return smalltalk.withContext(function($ctx2) { return self._presentResultNamed_withValue_(varName,value); }, function($ctx2) {$ctx2.fillBlock({varName:varName,value:value},$ctx1)})}); $1=self._executeCommand_(buffer); if(! smalltalk.assert($1)){ $2=self._isVariableDefined_(buffer); if(smalltalk.assert($2)){ _st(show)._value_value_(buffer,_st(self["@session"])._perform_(buffer)); } else { self._assignNewVariable_do_(buffer,show); }; }; return self}, function($ctx1) {$ctx1.fill(self,"processLine:",{buffer:buffer,show:show},smalltalk.Repl)})}, args: ["buffer"], source: "processLine: buffer\x0a\x09\x22Processes lines entered through the readline interface.\x22\x0a\x09| show |\x0a\x09show := [:varName :value | self presentResultNamed: varName withValue: value].\x0a\x09(self executeCommand: buffer) ifFalse: [\x0a\x09\x09(self isVariableDefined: buffer)\x0a\x09\x09\x09ifTrue: [show value: buffer value: (session perform: buffer)]\x0a\x09\x09\x09ifFalse: [self assignNewVariable: buffer do: show]]", messageSends: ["presentResultNamed:withValue:", "ifFalse:", "ifTrue:ifFalse:", "value:value:", "perform:", "assignNewVariable:do:", "isVariableDefined:", "executeCommand:"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "prompt", category: 'accessing', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { return "amber >> "; }, function($ctx1) {$ctx1.fill(self,"prompt",{},smalltalk.Repl)})}, args: [], source: "prompt\x0a\x09^'amber >> '", messageSends: [], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "setPreviousVariablesFor:from:", category: 'private', fn: function (newObject,oldObject){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._instanceVariableNamesFor_(_st(oldObject)._class()))._do_((function(each){ return smalltalk.withContext(function($ctx2) { return _st(newObject)._perform_withArguments_(_st(each).__comma(":"),[_st(oldObject)._perform_(each)]); }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"setPreviousVariablesFor:from:",{newObject:newObject,oldObject:oldObject},smalltalk.Repl)})}, args: ["newObject", "oldObject"], source: "setPreviousVariablesFor: newObject from: oldObject\x0a\x09(self instanceVariableNamesFor: oldObject class) do: [:each |\x0a\x09\x09newObject perform: each, ':' withArguments: {oldObject perform: each}].", messageSends: ["do:", "perform:withArguments:", ",", "perform:", "instanceVariableNamesFor:", "class"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "setPrompt", category: 'actions', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self["@interface"])._setPrompt_(self._prompt()); return self}, function($ctx1) {$ctx1.fill(self,"setPrompt",{},smalltalk.Repl)})}, args: [], source: "setPrompt\x0a\x09interface setPrompt: self prompt", messageSends: ["setPrompt:", "prompt"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "setupCommands", category: 'initialization', fn: function (){ var self=this; function $Dictionary(){return smalltalk.Dictionary||(typeof Dictionary=="undefined"?nil:Dictionary)} return smalltalk.withContext(function($ctx1) { self["@commands"]=_st($Dictionary())._from_([_st([":q"]).__minus_gt((function(){ return smalltalk.withContext(function($ctx2) { return _st(process)._exit(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})})),_st([""]).__minus_gt((function(){ return smalltalk.withContext(function($ctx2) { return _st(self["@interface"])._prompt(); }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))]); return self}, function($ctx1) {$ctx1.fill(self,"setupCommands",{},smalltalk.Repl)})}, args: [], source: "setupCommands\x0a\x09commands := Dictionary from: {\x0a\x09\x09{':q'} -> [process exit].\x0a\x09\x09{''} -> [interface prompt]}", messageSends: ["from:", "->", "exit", "prompt"], referencedClasses: ["Dictionary"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "setupHotkeys", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { var $1; _st(_st(process)._stdin())._on_do_("keypress",(function(s,key){ return smalltalk.withContext(function($ctx2) { $1=key; if(($receiver = $1) == nil || $receiver == undefined){ return $1; } else { return self._onKeyPress_(key); }; }, function($ctx2) {$ctx2.fillBlock({s:s,key:key},$ctx1)})})); return self}, function($ctx1) {$ctx1.fill(self,"setupHotkeys",{},smalltalk.Repl)})}, args: [], source: "setupHotkeys\x0a\x09process stdin on: 'keypress' do: [:s :key | key ifNotNil: [self onKeyPress: key]].", messageSends: ["on:do:", "ifNotNil:", "onKeyPress:", "stdin"], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "subclass:withVariable:", category: 'private', fn: function (aClass,varName){ var self=this; function $ClassBuilder(){return smalltalk.ClassBuilder||(typeof ClassBuilder=="undefined"?nil:ClassBuilder)} return smalltalk.withContext(function($ctx1) { var $1; $1=_st(_st($ClassBuilder())._new())._addSubclassOf_named_instanceVariableNames_package_(aClass,_st(self._subclassNameFor_(aClass))._asSymbol(),[varName],"Compiler-Core"); return $1; }, function($ctx1) {$ctx1.fill(self,"subclass:withVariable:",{aClass:aClass,varName:varName},smalltalk.Repl)})}, args: ["aClass", "varName"], source: "subclass: aClass withVariable: varName\x0a\x09\x22Create subclass with new variable.\x22\x0a\x09^ ClassBuilder new\x0a\x09\x09addSubclassOf: aClass\x0a\x09\x09named: (self subclassNameFor: aClass) asSymbol\x0a\x09\x09instanceVariableNames: {varName}\x0a\x09\x09package: 'Compiler-Core'", messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "asSymbol", "subclassNameFor:", "new"], referencedClasses: ["ClassBuilder"] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "subclassNameFor:", category: 'private', fn: function (aClass){ var self=this; return smalltalk.withContext(function($ctx1) { var $2,$1; $2=_st(_st(aClass)._name())._matchesOf_("\x5cd+$"); if(($receiver = $2) == nil || $receiver == undefined){ $1=_st(_st(aClass)._name()).__comma("2"); } else { var counter; counter=_st(_st(_st(_st(_st(aClass)._name())._matchesOf_("\x5cd+$"))._first())._asNumber()).__plus((1)); counter; $1=_st(_st(aClass)._name())._replaceRegexp_with_("\x5cd+$"._asRegexp(),_st(counter)._asString()); }; return $1; }, function($ctx1) {$ctx1.fill(self,"subclassNameFor:",{aClass:aClass},smalltalk.Repl)})}, args: ["aClass"], source: "subclassNameFor: aClass\x0a\x09^ (aClass name matchesOf: '\x5cd+$')\x0a\x09\x09ifNotNil: [ | counter |\x0a\x09\x09\x09counter := (aClass name matchesOf: '\x5cd+$') first asNumber + 1.\x0a\x09\x09\x09aClass name replaceRegexp: '\x5cd+$' asRegexp with: counter asString]\x0a\x09\x09ifNil: [\x0a\x09\x09\x09aClass name, '2'].", messageSends: ["ifNotNil:ifNil:", "+", "asNumber", "first", "matchesOf:", "name", "replaceRegexp:with:", "asRegexp", "asString", ","], referencedClasses: [] }), smalltalk.Repl); smalltalk.addMethod( smalltalk.method({ selector: "main", category: 'initialization', fn: function (){ var self=this; return smalltalk.withContext(function($ctx1) { _st(self._new())._createInterface(); return self}, function($ctx1) {$ctx1.fill(self,"main",{},smalltalk.Repl.klass)})}, args: [], source: "main\x0a\x09self new createInterface", messageSends: ["createInterface", "new"], referencedClasses: [] }), smalltalk.Repl.klass); }); define("amber_vm/_init", ["amber_vm/smalltalk","amber_vm/smalltalk","amber_vm/nil","amber_vm/_st","amber_core/Kernel-Objects","amber_core/Kernel-Classes","amber_core/Kernel-Methods","amber_core/Kernel-Collections","amber_core/Kernel-Infrastructure","amber_core/Kernel-Exceptions","amber_core/Kernel-Transcript","amber_core/Kernel-Announcements","amber_core/Compiler-Exceptions","amber_core/Compiler-Core","amber_core/Compiler-AST","amber_core/Compiler-IR","amber_core/Compiler-Inlining","amber_core/Compiler-Semantic","amber_core/Compiler-Interpreter","amber_vm/parser","amber_cli/AmberCli"], function (smalltalk) { smalltalk.initialize(); smalltalk.AmberCli._main(); }); requirejs("amber_vm/_init");