Compiler-Core.js 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145
  1. define(["amber/boot", "amber_core/Kernel-Collections", "amber_core/Kernel-Exceptions", "amber_core/Kernel-Objects"], function($boot){"use strict";
  2. if(!$boot.nilAsReceiver)$boot.nilAsReceiver=$boot.nil;
  3. var $core=$boot.api,nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
  4. if(!$boot.nilAsClass)$boot.nilAsClass=$boot.dnu;
  5. $core.addPackage('Compiler-Core');
  6. $core.packages["Compiler-Core"].innerEval = function (expr) { return eval(expr); };
  7. $core.packages["Compiler-Core"].transport = {"type":"amd","amdNamespace":"amber_core"};
  8. $core.addClass('AbstractCodeGenerator', $globals.Object, ['currentClass', 'currentPackage', 'source'], 'Compiler-Core');
  9. //>>excludeStart("ide", pragmas.excludeIdeData);
  10. $globals.AbstractCodeGenerator.comment="I am the abstract super class of all code generators and provide their common API.";
  11. //>>excludeEnd("ide");
  12. $core.addMethod(
  13. $core.method({
  14. selector: "compileNode:",
  15. protocol: 'compiling',
  16. fn: function (aNode){
  17. var self=this;
  18. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  19. return $core.withContext(function($ctx1) {
  20. //>>excludeEnd("ctx");
  21. return $recv(self._transformers())._inject_into_(aNode,(function(input,transformer){
  22. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  23. return $core.withContext(function($ctx2) {
  24. //>>excludeEnd("ctx");
  25. return $recv(transformer)._visit_(input);
  26. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  27. }, function($ctx2) {$ctx2.fillBlock({input:input,transformer:transformer},$ctx1,1)});
  28. //>>excludeEnd("ctx");
  29. }));
  30. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  31. }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode},$globals.AbstractCodeGenerator)});
  32. //>>excludeEnd("ctx");
  33. },
  34. //>>excludeStart("ide", pragmas.excludeIdeData);
  35. args: ["aNode"],
  36. source: "compileNode: aNode\x0a\x09^ self transformers\x0a\x09\x09inject: aNode\x0a\x09\x09into: [ :input :transformer | transformer visit: input ]",
  37. referencedClasses: [],
  38. //>>excludeEnd("ide");
  39. messageSends: ["inject:into:", "transformers", "visit:"]
  40. }),
  41. $globals.AbstractCodeGenerator);
  42. $core.addMethod(
  43. $core.method({
  44. selector: "currentClass",
  45. protocol: 'accessing',
  46. fn: function (){
  47. var self=this;
  48. return self["@currentClass"];
  49. },
  50. //>>excludeStart("ide", pragmas.excludeIdeData);
  51. args: [],
  52. source: "currentClass\x0a\x09^ currentClass",
  53. referencedClasses: [],
  54. //>>excludeEnd("ide");
  55. messageSends: []
  56. }),
  57. $globals.AbstractCodeGenerator);
  58. $core.addMethod(
  59. $core.method({
  60. selector: "currentClass:",
  61. protocol: 'accessing',
  62. fn: function (aClass){
  63. var self=this;
  64. self["@currentClass"]=aClass;
  65. return self;
  66. },
  67. //>>excludeStart("ide", pragmas.excludeIdeData);
  68. args: ["aClass"],
  69. source: "currentClass: aClass\x0a\x09currentClass := aClass",
  70. referencedClasses: [],
  71. //>>excludeEnd("ide");
  72. messageSends: []
  73. }),
  74. $globals.AbstractCodeGenerator);
  75. $core.addMethod(
  76. $core.method({
  77. selector: "currentPackage",
  78. protocol: 'accessing',
  79. fn: function (){
  80. var self=this;
  81. return self["@currentPackage"];
  82. },
  83. //>>excludeStart("ide", pragmas.excludeIdeData);
  84. args: [],
  85. source: "currentPackage\x0a\x09^ currentPackage",
  86. referencedClasses: [],
  87. //>>excludeEnd("ide");
  88. messageSends: []
  89. }),
  90. $globals.AbstractCodeGenerator);
  91. $core.addMethod(
  92. $core.method({
  93. selector: "currentPackage:",
  94. protocol: 'accessing',
  95. fn: function (anObject){
  96. var self=this;
  97. self["@currentPackage"]=anObject;
  98. return self;
  99. },
  100. //>>excludeStart("ide", pragmas.excludeIdeData);
  101. args: ["anObject"],
  102. source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
  103. referencedClasses: [],
  104. //>>excludeEnd("ide");
  105. messageSends: []
  106. }),
  107. $globals.AbstractCodeGenerator);
  108. $core.addMethod(
  109. $core.method({
  110. selector: "pseudoVariables",
  111. protocol: 'accessing',
  112. fn: function (){
  113. var self=this;
  114. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  115. return $core.withContext(function($ctx1) {
  116. //>>excludeEnd("ctx");
  117. return $recv($globals.Smalltalk)._pseudoVariableNames();
  118. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  119. }, function($ctx1) {$ctx1.fill(self,"pseudoVariables",{},$globals.AbstractCodeGenerator)});
  120. //>>excludeEnd("ctx");
  121. },
  122. //>>excludeStart("ide", pragmas.excludeIdeData);
  123. args: [],
  124. source: "pseudoVariables\x0a\x09^ Smalltalk pseudoVariableNames",
  125. referencedClasses: ["Smalltalk"],
  126. //>>excludeEnd("ide");
  127. messageSends: ["pseudoVariableNames"]
  128. }),
  129. $globals.AbstractCodeGenerator);
  130. $core.addMethod(
  131. $core.method({
  132. selector: "source",
  133. protocol: 'accessing',
  134. fn: function (){
  135. var self=this;
  136. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  137. return $core.withContext(function($ctx1) {
  138. //>>excludeEnd("ctx");
  139. var $1,$receiver;
  140. $1=self["@source"];
  141. if(($receiver = $1) == null || $receiver.isNil){
  142. return "";
  143. } else {
  144. return $1;
  145. }
  146. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  147. }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.AbstractCodeGenerator)});
  148. //>>excludeEnd("ctx");
  149. },
  150. //>>excludeStart("ide", pragmas.excludeIdeData);
  151. args: [],
  152. source: "source\x0a\x09^ source ifNil: [ '' ]",
  153. referencedClasses: [],
  154. //>>excludeEnd("ide");
  155. messageSends: ["ifNil:"]
  156. }),
  157. $globals.AbstractCodeGenerator);
  158. $core.addMethod(
  159. $core.method({
  160. selector: "source:",
  161. protocol: 'accessing',
  162. fn: function (aString){
  163. var self=this;
  164. self["@source"]=aString;
  165. return self;
  166. },
  167. //>>excludeStart("ide", pragmas.excludeIdeData);
  168. args: ["aString"],
  169. source: "source: aString\x0a\x09source := aString",
  170. referencedClasses: [],
  171. //>>excludeEnd("ide");
  172. messageSends: []
  173. }),
  174. $globals.AbstractCodeGenerator);
  175. $core.addMethod(
  176. $core.method({
  177. selector: "transformers",
  178. protocol: 'compiling',
  179. fn: function (){
  180. var self=this;
  181. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  182. return $core.withContext(function($ctx1) {
  183. //>>excludeEnd("ctx");
  184. self._subclassResponsibility();
  185. return self;
  186. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  187. }, function($ctx1) {$ctx1.fill(self,"transformers",{},$globals.AbstractCodeGenerator)});
  188. //>>excludeEnd("ctx");
  189. },
  190. //>>excludeStart("ide", pragmas.excludeIdeData);
  191. args: [],
  192. source: "transformers\x0a\x09self subclassResponsibility",
  193. referencedClasses: [],
  194. //>>excludeEnd("ide");
  195. messageSends: ["subclassResponsibility"]
  196. }),
  197. $globals.AbstractCodeGenerator);
  198. $core.addClass('CodeGenerator', $globals.AbstractCodeGenerator, [], 'Compiler-Core');
  199. //>>excludeStart("ide", pragmas.excludeIdeData);
  200. $globals.CodeGenerator.comment="I am a basic code generator. I generate a valid JavaScript output, but no not perform any inlining.\x0aSee `InliningCodeGenerator` for an optimized JavaScript code generation.";
  201. //>>excludeEnd("ide");
  202. $core.addMethod(
  203. $core.method({
  204. selector: "irTranslator",
  205. protocol: 'compiling',
  206. fn: function (){
  207. var self=this;
  208. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  209. return $core.withContext(function($ctx1) {
  210. //>>excludeEnd("ctx");
  211. return $recv($globals.IRJSTranslator)._new();
  212. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  213. }, function($ctx1) {$ctx1.fill(self,"irTranslator",{},$globals.CodeGenerator)});
  214. //>>excludeEnd("ctx");
  215. },
  216. //>>excludeStart("ide", pragmas.excludeIdeData);
  217. args: [],
  218. source: "irTranslator\x0a\x09^ IRJSTranslator new",
  219. referencedClasses: ["IRJSTranslator"],
  220. //>>excludeEnd("ide");
  221. messageSends: ["new"]
  222. }),
  223. $globals.CodeGenerator);
  224. $core.addMethod(
  225. $core.method({
  226. selector: "semanticAnalyzer",
  227. protocol: 'compiling',
  228. fn: function (){
  229. var self=this;
  230. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  231. return $core.withContext(function($ctx1) {
  232. //>>excludeEnd("ctx");
  233. var $1;
  234. $1=$recv($globals.SemanticAnalyzer)._on_(self._currentClass());
  235. $recv($1)._thePackage_(self._currentPackage());
  236. return $recv($1)._yourself();
  237. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  238. }, function($ctx1) {$ctx1.fill(self,"semanticAnalyzer",{},$globals.CodeGenerator)});
  239. //>>excludeEnd("ctx");
  240. },
  241. //>>excludeStart("ide", pragmas.excludeIdeData);
  242. args: [],
  243. source: "semanticAnalyzer\x0a\x09^ (SemanticAnalyzer on: self currentClass)\x0a\x09\x09thePackage: self currentPackage;\x0a\x09\x09yourself",
  244. referencedClasses: ["SemanticAnalyzer"],
  245. //>>excludeEnd("ide");
  246. messageSends: ["thePackage:", "on:", "currentClass", "currentPackage", "yourself"]
  247. }),
  248. $globals.CodeGenerator);
  249. $core.addMethod(
  250. $core.method({
  251. selector: "transformers",
  252. protocol: 'compiling',
  253. fn: function (){
  254. var self=this;
  255. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  256. return $core.withContext(function($ctx1) {
  257. //>>excludeEnd("ctx");
  258. var $1,$2,$4,$3;
  259. $1=self._semanticAnalyzer();
  260. $2=self._translator();
  261. $4=self._irTranslator();
  262. $recv($4)._currentClass_(self._currentClass());
  263. $3=$recv($4)._yourself();
  264. return [$1,$2,$3];
  265. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  266. }, function($ctx1) {$ctx1.fill(self,"transformers",{},$globals.CodeGenerator)});
  267. //>>excludeEnd("ctx");
  268. },
  269. //>>excludeStart("ide", pragmas.excludeIdeData);
  270. args: [],
  271. source: "transformers\x0a\x09^ {\x0a\x09\x09self semanticAnalyzer.\x0a\x09\x09self translator.\x0a\x09\x09self irTranslator currentClass: self currentClass; yourself\x0a\x09}",
  272. referencedClasses: [],
  273. //>>excludeEnd("ide");
  274. messageSends: ["semanticAnalyzer", "translator", "currentClass:", "irTranslator", "currentClass", "yourself"]
  275. }),
  276. $globals.CodeGenerator);
  277. $core.addMethod(
  278. $core.method({
  279. selector: "translator",
  280. protocol: 'compiling',
  281. fn: function (){
  282. var self=this;
  283. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  284. return $core.withContext(function($ctx1) {
  285. //>>excludeEnd("ctx");
  286. var $1;
  287. $1=$recv($globals.IRASTTranslator)._new();
  288. $recv($1)._source_(self._source());
  289. $recv($1)._theClass_(self._currentClass());
  290. return $recv($1)._yourself();
  291. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  292. }, function($ctx1) {$ctx1.fill(self,"translator",{},$globals.CodeGenerator)});
  293. //>>excludeEnd("ctx");
  294. },
  295. //>>excludeStart("ide", pragmas.excludeIdeData);
  296. args: [],
  297. source: "translator\x0a\x09^ IRASTTranslator new\x0a\x09\x09source: self source;\x0a\x09\x09theClass: self currentClass;\x0a\x09\x09yourself",
  298. referencedClasses: ["IRASTTranslator"],
  299. //>>excludeEnd("ide");
  300. messageSends: ["source:", "new", "source", "theClass:", "currentClass", "yourself"]
  301. }),
  302. $globals.CodeGenerator);
  303. $core.addClass('Compiler', $globals.Object, ['currentClass', 'currentPackage', 'source', 'unknownVariables', 'codeGeneratorClass'], 'Compiler-Core');
  304. //>>excludeStart("ide", pragmas.excludeIdeData);
  305. $globals.Compiler.comment="I provide the public interface for compiling Amber source code into JavaScript.\x0a\x0aThe code generator used to produce JavaScript can be plugged with `#codeGeneratorClass`.\x0aThe default code generator is an instance of `InlinedCodeGenerator`";
  306. //>>excludeEnd("ide");
  307. $core.addMethod(
  308. $core.method({
  309. selector: "codeGeneratorClass",
  310. protocol: 'accessing',
  311. fn: function (){
  312. var self=this;
  313. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  314. return $core.withContext(function($ctx1) {
  315. //>>excludeEnd("ctx");
  316. var $1,$receiver;
  317. $1=self["@codeGeneratorClass"];
  318. if(($receiver = $1) == null || $receiver.isNil){
  319. return $globals.InliningCodeGenerator;
  320. } else {
  321. return $1;
  322. }
  323. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  324. }, function($ctx1) {$ctx1.fill(self,"codeGeneratorClass",{},$globals.Compiler)});
  325. //>>excludeEnd("ctx");
  326. },
  327. //>>excludeStart("ide", pragmas.excludeIdeData);
  328. args: [],
  329. source: "codeGeneratorClass\x0a\x09^ codeGeneratorClass ifNil: [ InliningCodeGenerator ]",
  330. referencedClasses: ["InliningCodeGenerator"],
  331. //>>excludeEnd("ide");
  332. messageSends: ["ifNil:"]
  333. }),
  334. $globals.Compiler);
  335. $core.addMethod(
  336. $core.method({
  337. selector: "codeGeneratorClass:",
  338. protocol: 'accessing',
  339. fn: function (aClass){
  340. var self=this;
  341. self["@codeGeneratorClass"]=aClass;
  342. return self;
  343. },
  344. //>>excludeStart("ide", pragmas.excludeIdeData);
  345. args: ["aClass"],
  346. source: "codeGeneratorClass: aClass\x0a\x09codeGeneratorClass := aClass",
  347. referencedClasses: [],
  348. //>>excludeEnd("ide");
  349. messageSends: []
  350. }),
  351. $globals.Compiler);
  352. $core.addMethod(
  353. $core.method({
  354. selector: "compile:forClass:protocol:",
  355. protocol: 'compiling',
  356. fn: function (aString,aClass,anotherString){
  357. var self=this;
  358. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  359. return $core.withContext(function($ctx1) {
  360. //>>excludeEnd("ctx");
  361. self._source_(aString);
  362. return self._compileNode_forClass_package_(self._parse_(aString),aClass,$recv(aClass)._packageOfProtocol_(anotherString));
  363. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  364. }, function($ctx1) {$ctx1.fill(self,"compile:forClass:protocol:",{aString:aString,aClass:aClass,anotherString:anotherString},$globals.Compiler)});
  365. //>>excludeEnd("ctx");
  366. },
  367. //>>excludeStart("ide", pragmas.excludeIdeData);
  368. args: ["aString", "aClass", "anotherString"],
  369. source: "compile: aString forClass: aClass protocol: anotherString\x0a\x09^ self\x0a\x09\x09source: aString;\x0a\x09\x09compileNode: (self parse: aString)\x0a\x09\x09forClass: aClass\x0a\x09\x09package: (aClass packageOfProtocol: anotherString)",
  370. referencedClasses: [],
  371. //>>excludeEnd("ide");
  372. messageSends: ["source:", "compileNode:forClass:package:", "parse:", "packageOfProtocol:"]
  373. }),
  374. $globals.Compiler);
  375. $core.addMethod(
  376. $core.method({
  377. selector: "compileExpression:on:",
  378. protocol: 'compiling',
  379. fn: function (aString,anObject){
  380. var self=this;
  381. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  382. return $core.withContext(function($ctx1) {
  383. //>>excludeEnd("ctx");
  384. var $1;
  385. $1=$recv("xxxDoIt ^ [ ".__comma(aString)).__comma(" ] value");
  386. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  387. $ctx1.sendIdx[","]=1;
  388. //>>excludeEnd("ctx");
  389. return self._compile_forClass_protocol_($1,$recv(anObject)._class(),"**xxxDoIt");
  390. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  391. }, function($ctx1) {$ctx1.fill(self,"compileExpression:on:",{aString:aString,anObject:anObject},$globals.Compiler)});
  392. //>>excludeEnd("ctx");
  393. },
  394. //>>excludeStart("ide", pragmas.excludeIdeData);
  395. args: ["aString", "anObject"],
  396. source: "compileExpression: aString on: anObject\x0a\x09^ self\x0a\x09\x09compile: 'xxxDoIt ^ [ ', aString, ' ] value'\x0a\x09\x09forClass: anObject class\x0a\x09\x09protocol: '**xxxDoIt'",
  397. referencedClasses: [],
  398. //>>excludeEnd("ide");
  399. messageSends: ["compile:forClass:protocol:", ",", "class"]
  400. }),
  401. $globals.Compiler);
  402. $core.addMethod(
  403. $core.method({
  404. selector: "compileNode:",
  405. protocol: 'compiling',
  406. fn: function (aNode){
  407. var self=this;
  408. var generator,result;
  409. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  410. return $core.withContext(function($ctx1) {
  411. //>>excludeEnd("ctx");
  412. var $1;
  413. generator=$recv(self._codeGeneratorClass())._new();
  414. $1=generator;
  415. $recv($1)._source_(self._source());
  416. $recv($1)._currentClass_(self._currentClass());
  417. $recv($1)._currentPackage_(self._currentPackage());
  418. result=$recv(generator)._compileNode_(aNode);
  419. self._unknownVariables_([]);
  420. return result;
  421. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  422. }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,generator:generator,result:result},$globals.Compiler)});
  423. //>>excludeEnd("ctx");
  424. },
  425. //>>excludeStart("ide", pragmas.excludeIdeData);
  426. args: ["aNode"],
  427. source: "compileNode: aNode\x0a\x09| generator result |\x0a\x09generator := self codeGeneratorClass new.\x0a\x09generator\x0a\x09\x09source: self source;\x0a\x09\x09currentClass: self currentClass;\x0a\x09\x09currentPackage: self currentPackage.\x0a\x09result := generator compileNode: aNode.\x0a\x09self unknownVariables: #().\x0a\x09^ result",
  428. referencedClasses: [],
  429. //>>excludeEnd("ide");
  430. messageSends: ["new", "codeGeneratorClass", "source:", "source", "currentClass:", "currentClass", "currentPackage:", "currentPackage", "compileNode:", "unknownVariables:"]
  431. }),
  432. $globals.Compiler);
  433. $core.addMethod(
  434. $core.method({
  435. selector: "compileNode:forClass:package:",
  436. protocol: 'compiling',
  437. fn: function (aNode,aClass,aPackage){
  438. var self=this;
  439. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  440. return $core.withContext(function($ctx1) {
  441. //>>excludeEnd("ctx");
  442. self._currentClass_(aClass);
  443. self._currentPackage_(aPackage);
  444. return self._compileNode_(aNode);
  445. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  446. }, function($ctx1) {$ctx1.fill(self,"compileNode:forClass:package:",{aNode:aNode,aClass:aClass,aPackage:aPackage},$globals.Compiler)});
  447. //>>excludeEnd("ctx");
  448. },
  449. //>>excludeStart("ide", pragmas.excludeIdeData);
  450. args: ["aNode", "aClass", "aPackage"],
  451. source: "compileNode: aNode forClass: aClass package: aPackage\x0a\x09^ self\x0a\x09\x09currentClass: aClass;\x0a\x09\x09currentPackage: aPackage;\x0a\x09\x09compileNode: aNode",
  452. referencedClasses: [],
  453. //>>excludeEnd("ide");
  454. messageSends: ["currentClass:", "currentPackage:", "compileNode:"]
  455. }),
  456. $globals.Compiler);
  457. $core.addMethod(
  458. $core.method({
  459. selector: "currentClass",
  460. protocol: 'accessing',
  461. fn: function (){
  462. var self=this;
  463. return self["@currentClass"];
  464. },
  465. //>>excludeStart("ide", pragmas.excludeIdeData);
  466. args: [],
  467. source: "currentClass\x0a\x09^ currentClass",
  468. referencedClasses: [],
  469. //>>excludeEnd("ide");
  470. messageSends: []
  471. }),
  472. $globals.Compiler);
  473. $core.addMethod(
  474. $core.method({
  475. selector: "currentClass:",
  476. protocol: 'accessing',
  477. fn: function (aClass){
  478. var self=this;
  479. self["@currentClass"]=aClass;
  480. return self;
  481. },
  482. //>>excludeStart("ide", pragmas.excludeIdeData);
  483. args: ["aClass"],
  484. source: "currentClass: aClass\x0a\x09currentClass := aClass",
  485. referencedClasses: [],
  486. //>>excludeEnd("ide");
  487. messageSends: []
  488. }),
  489. $globals.Compiler);
  490. $core.addMethod(
  491. $core.method({
  492. selector: "currentPackage",
  493. protocol: 'accessing',
  494. fn: function (){
  495. var self=this;
  496. return self["@currentPackage"];
  497. },
  498. //>>excludeStart("ide", pragmas.excludeIdeData);
  499. args: [],
  500. source: "currentPackage\x0a\x09^ currentPackage",
  501. referencedClasses: [],
  502. //>>excludeEnd("ide");
  503. messageSends: []
  504. }),
  505. $globals.Compiler);
  506. $core.addMethod(
  507. $core.method({
  508. selector: "currentPackage:",
  509. protocol: 'accessing',
  510. fn: function (anObject){
  511. var self=this;
  512. self["@currentPackage"]=anObject;
  513. return self;
  514. },
  515. //>>excludeStart("ide", pragmas.excludeIdeData);
  516. args: ["anObject"],
  517. source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
  518. referencedClasses: [],
  519. //>>excludeEnd("ide");
  520. messageSends: []
  521. }),
  522. $globals.Compiler);
  523. $core.addMethod(
  524. $core.method({
  525. selector: "eval:",
  526. protocol: 'compiling',
  527. fn: function (aString){
  528. var self=this;
  529. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  530. return $core.withContext(function($ctx1) {
  531. //>>excludeEnd("ctx");
  532. return eval(aString);
  533. return self;
  534. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  535. }, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString},$globals.Compiler)});
  536. //>>excludeEnd("ctx");
  537. },
  538. //>>excludeStart("ide", pragmas.excludeIdeData);
  539. args: ["aString"],
  540. source: "eval: aString\x0a\x09<inlineJS: 'return eval(aString)'>",
  541. referencedClasses: [],
  542. //>>excludeEnd("ide");
  543. messageSends: []
  544. }),
  545. $globals.Compiler);
  546. $core.addMethod(
  547. $core.method({
  548. selector: "eval:forPackage:",
  549. protocol: 'compiling',
  550. fn: function (aString,aPackage){
  551. var self=this;
  552. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  553. return $core.withContext(function($ctx1) {
  554. //>>excludeEnd("ctx");
  555. return aPackage && aPackage.innerEval
  556. ? aPackage.innerEval(aString)
  557. : eval(aString);
  558. return self;
  559. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  560. }, function($ctx1) {$ctx1.fill(self,"eval:forPackage:",{aString:aString,aPackage:aPackage},$globals.Compiler)});
  561. //>>excludeEnd("ctx");
  562. },
  563. //>>excludeStart("ide", pragmas.excludeIdeData);
  564. args: ["aString", "aPackage"],
  565. source: "eval: aString forPackage: aPackage\x0a\x09<inlineJS: 'return aPackage && aPackage.innerEval\x0a\x09\x09? aPackage.innerEval(aString)\x0a\x09\x09: eval(aString)'>",
  566. referencedClasses: [],
  567. //>>excludeEnd("ide");
  568. messageSends: []
  569. }),
  570. $globals.Compiler);
  571. $core.addMethod(
  572. $core.method({
  573. selector: "evaluateExpression:",
  574. protocol: 'compiling',
  575. fn: function (aString){
  576. var self=this;
  577. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  578. return $core.withContext(function($ctx1) {
  579. //>>excludeEnd("ctx");
  580. return self._evaluateExpression_on_(aString,$recv($globals.DoIt)._new());
  581. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  582. }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:",{aString:aString},$globals.Compiler)});
  583. //>>excludeEnd("ctx");
  584. },
  585. //>>excludeStart("ide", pragmas.excludeIdeData);
  586. args: ["aString"],
  587. 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",
  588. referencedClasses: ["DoIt"],
  589. //>>excludeEnd("ide");
  590. messageSends: ["evaluateExpression:on:", "new"]
  591. }),
  592. $globals.Compiler);
  593. $core.addMethod(
  594. $core.method({
  595. selector: "evaluateExpression:on:",
  596. protocol: 'compiling',
  597. fn: function (aString,anObject){
  598. var self=this;
  599. var result,method;
  600. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  601. return $core.withContext(function($ctx1) {
  602. //>>excludeEnd("ctx");
  603. var $1;
  604. method=self._eval_(self._compileExpression_on_(aString,anObject));
  605. $recv(method)._protocol_("**xxxDoIt");
  606. $1=$recv(anObject)._class();
  607. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  608. $ctx1.sendIdx["class"]=1;
  609. //>>excludeEnd("ctx");
  610. $recv($1)._addCompiledMethod_(method);
  611. result=$recv(anObject)._xxxDoIt();
  612. $recv($recv(anObject)._class())._removeCompiledMethod_(method);
  613. return result;
  614. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  615. }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:on:",{aString:aString,anObject:anObject,result:result,method:method},$globals.Compiler)});
  616. //>>excludeEnd("ctx");
  617. },
  618. //>>excludeStart("ide", pragmas.excludeIdeData);
  619. args: ["aString", "anObject"],
  620. source: "evaluateExpression: aString on: anObject\x0a\x09\x22Unlike #eval: evaluate a Smalltalk expression with anObject as the receiver and answer the returned object\x22\x0a\x09| result method |\x0a\x09method := self eval: (self compileExpression: aString on: anObject).\x0a\x09method protocol: '**xxxDoIt'.\x0a\x09anObject class addCompiledMethod: method.\x0a\x09result := anObject xxxDoIt.\x0a\x09anObject class removeCompiledMethod: method.\x0a\x09^ result",
  621. referencedClasses: [],
  622. //>>excludeEnd("ide");
  623. messageSends: ["eval:", "compileExpression:on:", "protocol:", "addCompiledMethod:", "class", "xxxDoIt", "removeCompiledMethod:"]
  624. }),
  625. $globals.Compiler);
  626. $core.addMethod(
  627. $core.method({
  628. selector: "install:forClass:protocol:",
  629. protocol: 'compiling',
  630. fn: function (aString,aBehavior,anotherString){
  631. var self=this;
  632. var compiledMethod;
  633. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  634. return $core.withContext(function($ctx1) {
  635. //>>excludeEnd("ctx");
  636. compiledMethod=self._eval_forPackage_(self._compile_forClass_protocol_(aString,aBehavior,anotherString),$recv(aBehavior)._packageOfProtocol_(anotherString));
  637. return $recv($recv($globals.ClassBuilder)._new())._installMethod_forClass_protocol_(compiledMethod,aBehavior,anotherString);
  638. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  639. }, function($ctx1) {$ctx1.fill(self,"install:forClass:protocol:",{aString:aString,aBehavior:aBehavior,anotherString:anotherString,compiledMethod:compiledMethod},$globals.Compiler)});
  640. //>>excludeEnd("ctx");
  641. },
  642. //>>excludeStart("ide", pragmas.excludeIdeData);
  643. args: ["aString", "aBehavior", "anotherString"],
  644. source: "install: aString forClass: aBehavior protocol: anotherString\x0a\x09| compiledMethod |\x0a\x09compiledMethod := self\x0a\x09\x09eval: (self compile: aString forClass: aBehavior protocol: anotherString)\x0a\x09\x09forPackage: (aBehavior packageOfProtocol: anotherString).\x0a\x09^ ClassBuilder new\x0a\x09\x09installMethod: compiledMethod\x0a\x09\x09forClass: aBehavior\x0a\x09\x09protocol: anotherString",
  645. referencedClasses: ["ClassBuilder"],
  646. //>>excludeEnd("ide");
  647. messageSends: ["eval:forPackage:", "compile:forClass:protocol:", "packageOfProtocol:", "installMethod:forClass:protocol:", "new"]
  648. }),
  649. $globals.Compiler);
  650. $core.addMethod(
  651. $core.method({
  652. selector: "parse:",
  653. protocol: 'compiling',
  654. fn: function (aString){
  655. var self=this;
  656. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  657. return $core.withContext(function($ctx1) {
  658. //>>excludeEnd("ctx");
  659. return $recv($globals.Smalltalk)._parse_(aString);
  660. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  661. }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},$globals.Compiler)});
  662. //>>excludeEnd("ctx");
  663. },
  664. //>>excludeStart("ide", pragmas.excludeIdeData);
  665. args: ["aString"],
  666. source: "parse: aString\x0a\x09^ Smalltalk parse: aString",
  667. referencedClasses: ["Smalltalk"],
  668. //>>excludeEnd("ide");
  669. messageSends: ["parse:"]
  670. }),
  671. $globals.Compiler);
  672. $core.addMethod(
  673. $core.method({
  674. selector: "parseExpression:",
  675. protocol: 'compiling',
  676. fn: function (aString){
  677. var self=this;
  678. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  679. return $core.withContext(function($ctx1) {
  680. //>>excludeEnd("ctx");
  681. var $1;
  682. $1=$recv("doIt ^ [ ".__comma(aString)).__comma(" ] value");
  683. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  684. $ctx1.sendIdx[","]=1;
  685. //>>excludeEnd("ctx");
  686. return self._parse_($1);
  687. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  688. }, function($ctx1) {$ctx1.fill(self,"parseExpression:",{aString:aString},$globals.Compiler)});
  689. //>>excludeEnd("ctx");
  690. },
  691. //>>excludeStart("ide", pragmas.excludeIdeData);
  692. args: ["aString"],
  693. source: "parseExpression: aString\x0a\x09^ self parse: 'doIt ^ [ ', aString, ' ] value'",
  694. referencedClasses: [],
  695. //>>excludeEnd("ide");
  696. messageSends: ["parse:", ","]
  697. }),
  698. $globals.Compiler);
  699. $core.addMethod(
  700. $core.method({
  701. selector: "recompile:",
  702. protocol: 'compiling',
  703. fn: function (aClass){
  704. var self=this;
  705. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  706. return $core.withContext(function($ctx1) {
  707. //>>excludeEnd("ctx");
  708. var $1;
  709. $recv($recv($recv(aClass)._methodDictionary())._values())._do_displayingProgress_((function(each){
  710. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  711. return $core.withContext(function($ctx2) {
  712. //>>excludeEnd("ctx");
  713. return self._install_forClass_protocol_($recv(each)._source(),aClass,$recv(each)._protocol());
  714. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  715. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  716. //>>excludeEnd("ctx");
  717. }),"Recompiling ".__comma($recv(aClass)._name()));
  718. $1=$recv(aClass)._isMetaclass();
  719. if(!$core.assert($1)){
  720. self._recompile_($recv(aClass)._class());
  721. }
  722. return self;
  723. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  724. }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler)});
  725. //>>excludeEnd("ctx");
  726. },
  727. //>>excludeStart("ide", pragmas.excludeIdeData);
  728. args: ["aClass"],
  729. source: "recompile: aClass\x0a\x09aClass methodDictionary values\x0a\x09\x09do: [ :each | \x0a\x09\x09\x09self \x0a\x09\x09\x09\x09install: each source \x0a\x09\x09\x09\x09forClass: aClass \x0a\x09\x09\x09\x09protocol: each protocol ]\x0a\x09\x09displayingProgress: 'Recompiling ', aClass name.\x0a\x09aClass isMetaclass ifFalse: [ self recompile: aClass class ]",
  730. referencedClasses: [],
  731. //>>excludeEnd("ide");
  732. messageSends: ["do:displayingProgress:", "values", "methodDictionary", "install:forClass:protocol:", "source", "protocol", ",", "name", "ifFalse:", "isMetaclass", "recompile:", "class"]
  733. }),
  734. $globals.Compiler);
  735. $core.addMethod(
  736. $core.method({
  737. selector: "recompileAll",
  738. protocol: 'compiling',
  739. fn: function (){
  740. var self=this;
  741. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  742. return $core.withContext(function($ctx1) {
  743. //>>excludeEnd("ctx");
  744. $recv($recv($globals.Smalltalk)._classes())._do_displayingProgress_((function(each){
  745. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  746. return $core.withContext(function($ctx2) {
  747. //>>excludeEnd("ctx");
  748. return self._recompile_(each);
  749. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  750. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  751. //>>excludeEnd("ctx");
  752. }),"Compiling all classes...");
  753. return self;
  754. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  755. }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler)});
  756. //>>excludeEnd("ctx");
  757. },
  758. //>>excludeStart("ide", pragmas.excludeIdeData);
  759. args: [],
  760. source: "recompileAll\x0a\x09Smalltalk classes \x0a\x09\x09do: [ :each | self recompile: each ]\x0a\x09\x09displayingProgress: 'Compiling all classes...'",
  761. referencedClasses: ["Smalltalk"],
  762. //>>excludeEnd("ide");
  763. messageSends: ["do:displayingProgress:", "classes", "recompile:"]
  764. }),
  765. $globals.Compiler);
  766. $core.addMethod(
  767. $core.method({
  768. selector: "source",
  769. protocol: 'accessing',
  770. fn: function (){
  771. var self=this;
  772. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  773. return $core.withContext(function($ctx1) {
  774. //>>excludeEnd("ctx");
  775. var $1,$receiver;
  776. $1=self["@source"];
  777. if(($receiver = $1) == null || $receiver.isNil){
  778. return "";
  779. } else {
  780. return $1;
  781. }
  782. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  783. }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.Compiler)});
  784. //>>excludeEnd("ctx");
  785. },
  786. //>>excludeStart("ide", pragmas.excludeIdeData);
  787. args: [],
  788. source: "source\x0a\x09^ source ifNil: [ '' ]",
  789. referencedClasses: [],
  790. //>>excludeEnd("ide");
  791. messageSends: ["ifNil:"]
  792. }),
  793. $globals.Compiler);
  794. $core.addMethod(
  795. $core.method({
  796. selector: "source:",
  797. protocol: 'accessing',
  798. fn: function (aString){
  799. var self=this;
  800. self["@source"]=aString;
  801. return self;
  802. },
  803. //>>excludeStart("ide", pragmas.excludeIdeData);
  804. args: ["aString"],
  805. source: "source: aString\x0a\x09source := aString",
  806. referencedClasses: [],
  807. //>>excludeEnd("ide");
  808. messageSends: []
  809. }),
  810. $globals.Compiler);
  811. $core.addMethod(
  812. $core.method({
  813. selector: "unknownVariables",
  814. protocol: 'accessing',
  815. fn: function (){
  816. var self=this;
  817. return self["@unknownVariables"];
  818. },
  819. //>>excludeStart("ide", pragmas.excludeIdeData);
  820. args: [],
  821. source: "unknownVariables\x0a\x09^ unknownVariables",
  822. referencedClasses: [],
  823. //>>excludeEnd("ide");
  824. messageSends: []
  825. }),
  826. $globals.Compiler);
  827. $core.addMethod(
  828. $core.method({
  829. selector: "unknownVariables:",
  830. protocol: 'accessing',
  831. fn: function (aCollection){
  832. var self=this;
  833. self["@unknownVariables"]=aCollection;
  834. return self;
  835. },
  836. //>>excludeStart("ide", pragmas.excludeIdeData);
  837. args: ["aCollection"],
  838. source: "unknownVariables: aCollection\x0a\x09unknownVariables := aCollection",
  839. referencedClasses: [],
  840. //>>excludeEnd("ide");
  841. messageSends: []
  842. }),
  843. $globals.Compiler);
  844. $core.addMethod(
  845. $core.method({
  846. selector: "recompile:",
  847. protocol: 'compiling',
  848. fn: function (aClass){
  849. var self=this;
  850. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  851. return $core.withContext(function($ctx1) {
  852. //>>excludeEnd("ctx");
  853. $recv(self._new())._recompile_(aClass);
  854. return self;
  855. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  856. }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler.klass)});
  857. //>>excludeEnd("ctx");
  858. },
  859. //>>excludeStart("ide", pragmas.excludeIdeData);
  860. args: ["aClass"],
  861. source: "recompile: aClass\x0a\x09self new recompile: aClass",
  862. referencedClasses: [],
  863. //>>excludeEnd("ide");
  864. messageSends: ["recompile:", "new"]
  865. }),
  866. $globals.Compiler.klass);
  867. $core.addMethod(
  868. $core.method({
  869. selector: "recompileAll",
  870. protocol: 'compiling',
  871. fn: function (){
  872. var self=this;
  873. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  874. return $core.withContext(function($ctx1) {
  875. //>>excludeEnd("ctx");
  876. $recv($recv($globals.Smalltalk)._classes())._do_((function(each){
  877. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  878. return $core.withContext(function($ctx2) {
  879. //>>excludeEnd("ctx");
  880. return self._recompile_(each);
  881. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  882. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  883. //>>excludeEnd("ctx");
  884. }));
  885. return self;
  886. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  887. }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler.klass)});
  888. //>>excludeEnd("ctx");
  889. },
  890. //>>excludeStart("ide", pragmas.excludeIdeData);
  891. args: [],
  892. source: "recompileAll\x0a\x09Smalltalk classes do: [ :each |\x0a\x09\x09self recompile: each ]",
  893. referencedClasses: ["Smalltalk"],
  894. //>>excludeEnd("ide");
  895. messageSends: ["do:", "classes", "recompile:"]
  896. }),
  897. $globals.Compiler.klass);
  898. $core.addClass('CompilerError', $globals.Error, [], 'Compiler-Core');
  899. //>>excludeStart("ide", pragmas.excludeIdeData);
  900. $globals.CompilerError.comment="I am the common superclass of all compiling errors.";
  901. //>>excludeEnd("ide");
  902. $core.addClass('DoIt', $globals.Object, [], 'Compiler-Core');
  903. //>>excludeStart("ide", pragmas.excludeIdeData);
  904. $globals.DoIt.comment="`DoIt` is the class used to compile and evaluate expressions. See `Compiler >> evaluateExpression:`.";
  905. //>>excludeEnd("ide");
  906. $core.addClass('Evaluator', $globals.Object, [], 'Compiler-Core');
  907. //>>excludeStart("ide", pragmas.excludeIdeData);
  908. $globals.Evaluator.comment="I evaluate code against a receiver, dispatching #evaluate:on: to the receiver.";
  909. //>>excludeEnd("ide");
  910. $core.addMethod(
  911. $core.method({
  912. selector: "evaluate:context:",
  913. protocol: 'evaluating',
  914. fn: function (aString,aContext){
  915. var self=this;
  916. var compiler,ast;
  917. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  918. return $core.withContext(function($ctx1) {
  919. //>>excludeEnd("ctx");
  920. var $1;
  921. var $early={};
  922. try {
  923. compiler=$recv($globals.Compiler)._new();
  924. $recv((function(){
  925. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  926. return $core.withContext(function($ctx2) {
  927. //>>excludeEnd("ctx");
  928. ast=$recv(compiler)._parseExpression_(aString);
  929. return ast;
  930. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  931. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  932. //>>excludeEnd("ctx");
  933. }))._on_do_($globals.Error,(function(ex){
  934. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  935. return $core.withContext(function($ctx2) {
  936. //>>excludeEnd("ctx");
  937. throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
  938. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  939. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
  940. //>>excludeEnd("ctx");
  941. }));
  942. $1=$recv($globals.AISemanticAnalyzer)._on_($recv($recv(aContext)._receiver())._class());
  943. $recv($1)._context_(aContext);
  944. $recv($1)._visit_(ast);
  945. return $recv(aContext)._evaluateNode_(ast);
  946. }
  947. catch(e) {if(e===$early)return e[0]; throw e}
  948. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  949. }, function($ctx1) {$ctx1.fill(self,"evaluate:context:",{aString:aString,aContext:aContext,compiler:compiler,ast:ast},$globals.Evaluator)});
  950. //>>excludeEnd("ctx");
  951. },
  952. //>>excludeStart("ide", pragmas.excludeIdeData);
  953. args: ["aString", "aContext"],
  954. source: "evaluate: aString context: aContext\x0a\x09\x22Similar to #evaluate:for:, with the following differences:\x0a\x09- instead of compiling and running `aString`, `aString` is interpreted using an `ASTInterpreter`\x0a\x09- instead of evaluating against a receiver, evaluate in the context of `aContext`\x22\x0a\x0a\x09| compiler ast |\x0a\x09\x0a\x09compiler := Compiler new.\x0a\x09[ ast := compiler parseExpression: aString ] \x0a\x09\x09on: Error \x0a\x09\x09do: [ :ex | ^ Terminal alert: ex messageText ].\x0a\x09\x09\x0a\x09(AISemanticAnalyzer on: aContext receiver class)\x0a\x09\x09context: aContext;\x0a\x09\x09visit: ast.\x0a\x0a\x09^ aContext evaluateNode: ast",
  955. referencedClasses: ["Compiler", "Error", "Terminal", "AISemanticAnalyzer"],
  956. //>>excludeEnd("ide");
  957. messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "context:", "on:", "class", "receiver", "visit:", "evaluateNode:"]
  958. }),
  959. $globals.Evaluator);
  960. $core.addMethod(
  961. $core.method({
  962. selector: "evaluate:for:",
  963. protocol: 'evaluating',
  964. fn: function (aString,anObject){
  965. var self=this;
  966. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  967. return $core.withContext(function($ctx1) {
  968. //>>excludeEnd("ctx");
  969. return $recv(anObject)._evaluate_on_(aString,self);
  970. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  971. }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator)});
  972. //>>excludeEnd("ctx");
  973. },
  974. //>>excludeStart("ide", pragmas.excludeIdeData);
  975. args: ["aString", "anObject"],
  976. source: "evaluate: aString for: anObject\x0a\x09^ anObject evaluate: aString on: self",
  977. referencedClasses: [],
  978. //>>excludeEnd("ide");
  979. messageSends: ["evaluate:on:"]
  980. }),
  981. $globals.Evaluator);
  982. $core.addMethod(
  983. $core.method({
  984. selector: "evaluate:receiver:",
  985. protocol: 'evaluating',
  986. fn: function (aString,anObject){
  987. var self=this;
  988. var compiler;
  989. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  990. return $core.withContext(function($ctx1) {
  991. //>>excludeEnd("ctx");
  992. var $early={};
  993. try {
  994. compiler=$recv($globals.Compiler)._new();
  995. $recv((function(){
  996. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  997. return $core.withContext(function($ctx2) {
  998. //>>excludeEnd("ctx");
  999. return $recv(compiler)._parseExpression_(aString);
  1000. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1001. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1002. //>>excludeEnd("ctx");
  1003. }))._on_do_($globals.Error,(function(ex){
  1004. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1005. return $core.withContext(function($ctx2) {
  1006. //>>excludeEnd("ctx");
  1007. throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
  1008. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1009. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
  1010. //>>excludeEnd("ctx");
  1011. }));
  1012. return $recv(compiler)._evaluateExpression_on_(aString,anObject);
  1013. }
  1014. catch(e) {if(e===$early)return e[0]; throw e}
  1015. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1016. }, function($ctx1) {$ctx1.fill(self,"evaluate:receiver:",{aString:aString,anObject:anObject,compiler:compiler},$globals.Evaluator)});
  1017. //>>excludeEnd("ctx");
  1018. },
  1019. //>>excludeStart("ide", pragmas.excludeIdeData);
  1020. args: ["aString", "anObject"],
  1021. source: "evaluate: aString receiver: anObject\x0a\x09| compiler |\x0a\x09\x0a\x09compiler := Compiler new.\x0a\x09[ compiler parseExpression: aString ] \x0a\x09\x09on: Error \x0a\x09\x09do: [ :ex | ^ Terminal alert: ex messageText ].\x0a\x0a\x09^ compiler evaluateExpression: aString on: anObject",
  1022. referencedClasses: ["Compiler", "Error", "Terminal"],
  1023. //>>excludeEnd("ide");
  1024. messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "evaluateExpression:on:"]
  1025. }),
  1026. $globals.Evaluator);
  1027. $core.addMethod(
  1028. $core.method({
  1029. selector: "evaluate:for:",
  1030. protocol: 'instance creation',
  1031. fn: function (aString,anObject){
  1032. var self=this;
  1033. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1034. return $core.withContext(function($ctx1) {
  1035. //>>excludeEnd("ctx");
  1036. return $recv(self._new())._evaluate_for_(aString,anObject);
  1037. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1038. }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator.klass)});
  1039. //>>excludeEnd("ctx");
  1040. },
  1041. //>>excludeStart("ide", pragmas.excludeIdeData);
  1042. args: ["aString", "anObject"],
  1043. source: "evaluate: aString for: anObject\x0a\x09^ self new evaluate: aString for: anObject",
  1044. referencedClasses: [],
  1045. //>>excludeEnd("ide");
  1046. messageSends: ["evaluate:for:", "new"]
  1047. }),
  1048. $globals.Evaluator.klass);
  1049. $core.addMethod(
  1050. $core.method({
  1051. selector: "asVariableName",
  1052. protocol: '*Compiler-Core',
  1053. fn: function (){
  1054. var self=this;
  1055. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1056. return $core.withContext(function($ctx1) {
  1057. //>>excludeEnd("ctx");
  1058. var $1;
  1059. $1=$recv($recv($globals.Smalltalk)._reservedWords())._includes_(self);
  1060. if($core.assert($1)){
  1061. return self.__comma("_");
  1062. } else {
  1063. return self;
  1064. }
  1065. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1066. }, function($ctx1) {$ctx1.fill(self,"asVariableName",{},$globals.String)});
  1067. //>>excludeEnd("ctx");
  1068. },
  1069. //>>excludeStart("ide", pragmas.excludeIdeData);
  1070. args: [],
  1071. source: "asVariableName\x0a\x09^ (Smalltalk reservedWords includes: self)\x0a\x09\x09ifTrue: [ self, '_' ]\x0a\x09\x09ifFalse: [ self ]",
  1072. referencedClasses: ["Smalltalk"],
  1073. //>>excludeEnd("ide");
  1074. messageSends: ["ifTrue:ifFalse:", "includes:", "reservedWords", ","]
  1075. }),
  1076. $globals.String);
  1077. });