Compiler-Core.js 39 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163
  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(self._semanticAnalyzerClass())._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^ (self semanticAnalyzerClass on: self currentClass)\x0a\x09\x09thePackage: self currentPackage;\x0a\x09\x09yourself",
  244. referencedClasses: [],
  245. //>>excludeEnd("ide");
  246. messageSends: ["thePackage:", "on:", "semanticAnalyzerClass", "currentClass", "currentPackage", "yourself"]
  247. }),
  248. $globals.CodeGenerator);
  249. $core.addMethod(
  250. $core.method({
  251. selector: "semanticAnalyzerClass",
  252. protocol: 'compiling',
  253. fn: function (){
  254. var self=this;
  255. return $globals.SemanticAnalyzer;
  256. },
  257. //>>excludeStart("ide", pragmas.excludeIdeData);
  258. args: [],
  259. source: "semanticAnalyzerClass\x0a\x09^ SemanticAnalyzer",
  260. referencedClasses: ["SemanticAnalyzer"],
  261. //>>excludeEnd("ide");
  262. messageSends: []
  263. }),
  264. $globals.CodeGenerator);
  265. $core.addMethod(
  266. $core.method({
  267. selector: "transformers",
  268. protocol: 'compiling',
  269. fn: function (){
  270. var self=this;
  271. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  272. return $core.withContext(function($ctx1) {
  273. //>>excludeEnd("ctx");
  274. var $1,$2,$4,$3;
  275. $1=self._semanticAnalyzer();
  276. $2=self._translator();
  277. $4=self._irTranslator();
  278. $recv($4)._currentClass_(self._currentClass());
  279. $3=$recv($4)._yourself();
  280. return [$1,$2,$3];
  281. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  282. }, function($ctx1) {$ctx1.fill(self,"transformers",{},$globals.CodeGenerator)});
  283. //>>excludeEnd("ctx");
  284. },
  285. //>>excludeStart("ide", pragmas.excludeIdeData);
  286. args: [],
  287. source: "transformers\x0a\x09^ {\x0a\x09\x09self semanticAnalyzer.\x0a\x09\x09self translator.\x0a\x09\x09self irTranslator currentClass: self currentClass; yourself\x0a\x09}",
  288. referencedClasses: [],
  289. //>>excludeEnd("ide");
  290. messageSends: ["semanticAnalyzer", "translator", "currentClass:", "irTranslator", "currentClass", "yourself"]
  291. }),
  292. $globals.CodeGenerator);
  293. $core.addMethod(
  294. $core.method({
  295. selector: "translator",
  296. protocol: 'compiling',
  297. fn: function (){
  298. var self=this;
  299. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  300. return $core.withContext(function($ctx1) {
  301. //>>excludeEnd("ctx");
  302. var $1;
  303. $1=$recv($globals.IRASTTranslator)._new();
  304. $recv($1)._source_(self._source());
  305. $recv($1)._theClass_(self._currentClass());
  306. return $recv($1)._yourself();
  307. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  308. }, function($ctx1) {$ctx1.fill(self,"translator",{},$globals.CodeGenerator)});
  309. //>>excludeEnd("ctx");
  310. },
  311. //>>excludeStart("ide", pragmas.excludeIdeData);
  312. args: [],
  313. source: "translator\x0a\x09^ IRASTTranslator new\x0a\x09\x09source: self source;\x0a\x09\x09theClass: self currentClass;\x0a\x09\x09yourself",
  314. referencedClasses: ["IRASTTranslator"],
  315. //>>excludeEnd("ide");
  316. messageSends: ["source:", "new", "source", "theClass:", "currentClass", "yourself"]
  317. }),
  318. $globals.CodeGenerator);
  319. $core.addClass('Compiler', $globals.Object, ['currentClass', 'currentPackage', 'source', 'unknownVariables', 'codeGeneratorClass'], 'Compiler-Core');
  320. //>>excludeStart("ide", pragmas.excludeIdeData);
  321. $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`";
  322. //>>excludeEnd("ide");
  323. $core.addMethod(
  324. $core.method({
  325. selector: "codeGeneratorClass",
  326. protocol: 'accessing',
  327. fn: function (){
  328. var self=this;
  329. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  330. return $core.withContext(function($ctx1) {
  331. //>>excludeEnd("ctx");
  332. var $1,$receiver;
  333. $1=self["@codeGeneratorClass"];
  334. if(($receiver = $1) == null || $receiver.isNil){
  335. return $globals.InliningCodeGenerator;
  336. } else {
  337. return $1;
  338. }
  339. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  340. }, function($ctx1) {$ctx1.fill(self,"codeGeneratorClass",{},$globals.Compiler)});
  341. //>>excludeEnd("ctx");
  342. },
  343. //>>excludeStart("ide", pragmas.excludeIdeData);
  344. args: [],
  345. source: "codeGeneratorClass\x0a\x09^ codeGeneratorClass ifNil: [ InliningCodeGenerator ]",
  346. referencedClasses: ["InliningCodeGenerator"],
  347. //>>excludeEnd("ide");
  348. messageSends: ["ifNil:"]
  349. }),
  350. $globals.Compiler);
  351. $core.addMethod(
  352. $core.method({
  353. selector: "codeGeneratorClass:",
  354. protocol: 'accessing',
  355. fn: function (aClass){
  356. var self=this;
  357. self["@codeGeneratorClass"]=aClass;
  358. return self;
  359. },
  360. //>>excludeStart("ide", pragmas.excludeIdeData);
  361. args: ["aClass"],
  362. source: "codeGeneratorClass: aClass\x0a\x09codeGeneratorClass := aClass",
  363. referencedClasses: [],
  364. //>>excludeEnd("ide");
  365. messageSends: []
  366. }),
  367. $globals.Compiler);
  368. $core.addMethod(
  369. $core.method({
  370. selector: "compile:forClass:protocol:",
  371. protocol: 'compiling',
  372. fn: function (aString,aClass,anotherString){
  373. var self=this;
  374. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  375. return $core.withContext(function($ctx1) {
  376. //>>excludeEnd("ctx");
  377. self._source_(aString);
  378. return self._compileNode_forClass_package_(self._parse_(aString),aClass,$recv(aClass)._packageOfProtocol_(anotherString));
  379. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  380. }, function($ctx1) {$ctx1.fill(self,"compile:forClass:protocol:",{aString:aString,aClass:aClass,anotherString:anotherString},$globals.Compiler)});
  381. //>>excludeEnd("ctx");
  382. },
  383. //>>excludeStart("ide", pragmas.excludeIdeData);
  384. args: ["aString", "aClass", "anotherString"],
  385. 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)",
  386. referencedClasses: [],
  387. //>>excludeEnd("ide");
  388. messageSends: ["source:", "compileNode:forClass:package:", "parse:", "packageOfProtocol:"]
  389. }),
  390. $globals.Compiler);
  391. $core.addMethod(
  392. $core.method({
  393. selector: "compileExpression:on:",
  394. protocol: 'compiling',
  395. fn: function (aString,anObject){
  396. var self=this;
  397. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  398. return $core.withContext(function($ctx1) {
  399. //>>excludeEnd("ctx");
  400. var $1;
  401. $1=$recv("xxxDoIt ^ [ ".__comma(aString)).__comma(" ] value");
  402. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  403. $ctx1.sendIdx[","]=1;
  404. //>>excludeEnd("ctx");
  405. return self._compile_forClass_protocol_($1,$recv(anObject)._class(),"**xxxDoIt");
  406. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  407. }, function($ctx1) {$ctx1.fill(self,"compileExpression:on:",{aString:aString,anObject:anObject},$globals.Compiler)});
  408. //>>excludeEnd("ctx");
  409. },
  410. //>>excludeStart("ide", pragmas.excludeIdeData);
  411. args: ["aString", "anObject"],
  412. source: "compileExpression: aString on: anObject\x0a\x09^ self\x0a\x09\x09compile: 'xxxDoIt ^ [ ', aString, ' ] value'\x0a\x09\x09forClass: anObject class\x0a\x09\x09protocol: '**xxxDoIt'",
  413. referencedClasses: [],
  414. //>>excludeEnd("ide");
  415. messageSends: ["compile:forClass:protocol:", ",", "class"]
  416. }),
  417. $globals.Compiler);
  418. $core.addMethod(
  419. $core.method({
  420. selector: "compileNode:",
  421. protocol: 'compiling',
  422. fn: function (aNode){
  423. var self=this;
  424. var generator,result;
  425. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  426. return $core.withContext(function($ctx1) {
  427. //>>excludeEnd("ctx");
  428. var $1;
  429. generator=$recv(self._codeGeneratorClass())._new();
  430. $1=generator;
  431. $recv($1)._source_(self._source());
  432. $recv($1)._currentClass_(self._currentClass());
  433. $recv($1)._currentPackage_(self._currentPackage());
  434. result=$recv(generator)._compileNode_(aNode);
  435. self._unknownVariables_([]);
  436. return result;
  437. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  438. }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,generator:generator,result:result},$globals.Compiler)});
  439. //>>excludeEnd("ctx");
  440. },
  441. //>>excludeStart("ide", pragmas.excludeIdeData);
  442. args: ["aNode"],
  443. 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",
  444. referencedClasses: [],
  445. //>>excludeEnd("ide");
  446. messageSends: ["new", "codeGeneratorClass", "source:", "source", "currentClass:", "currentClass", "currentPackage:", "currentPackage", "compileNode:", "unknownVariables:"]
  447. }),
  448. $globals.Compiler);
  449. $core.addMethod(
  450. $core.method({
  451. selector: "compileNode:forClass:package:",
  452. protocol: 'compiling',
  453. fn: function (aNode,aClass,aPackage){
  454. var self=this;
  455. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  456. return $core.withContext(function($ctx1) {
  457. //>>excludeEnd("ctx");
  458. self._currentClass_(aClass);
  459. self._currentPackage_(aPackage);
  460. return self._compileNode_(aNode);
  461. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  462. }, function($ctx1) {$ctx1.fill(self,"compileNode:forClass:package:",{aNode:aNode,aClass:aClass,aPackage:aPackage},$globals.Compiler)});
  463. //>>excludeEnd("ctx");
  464. },
  465. //>>excludeStart("ide", pragmas.excludeIdeData);
  466. args: ["aNode", "aClass", "aPackage"],
  467. source: "compileNode: aNode forClass: aClass package: aPackage\x0a\x09^ self\x0a\x09\x09currentClass: aClass;\x0a\x09\x09currentPackage: aPackage;\x0a\x09\x09compileNode: aNode",
  468. referencedClasses: [],
  469. //>>excludeEnd("ide");
  470. messageSends: ["currentClass:", "currentPackage:", "compileNode:"]
  471. }),
  472. $globals.Compiler);
  473. $core.addMethod(
  474. $core.method({
  475. selector: "currentClass",
  476. protocol: 'accessing',
  477. fn: function (){
  478. var self=this;
  479. return self["@currentClass"];
  480. },
  481. //>>excludeStart("ide", pragmas.excludeIdeData);
  482. args: [],
  483. source: "currentClass\x0a\x09^ currentClass",
  484. referencedClasses: [],
  485. //>>excludeEnd("ide");
  486. messageSends: []
  487. }),
  488. $globals.Compiler);
  489. $core.addMethod(
  490. $core.method({
  491. selector: "currentClass:",
  492. protocol: 'accessing',
  493. fn: function (aClass){
  494. var self=this;
  495. self["@currentClass"]=aClass;
  496. return self;
  497. },
  498. //>>excludeStart("ide", pragmas.excludeIdeData);
  499. args: ["aClass"],
  500. source: "currentClass: aClass\x0a\x09currentClass := aClass",
  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 (){
  511. var self=this;
  512. return self["@currentPackage"];
  513. },
  514. //>>excludeStart("ide", pragmas.excludeIdeData);
  515. args: [],
  516. source: "currentPackage\x0a\x09^ currentPackage",
  517. referencedClasses: [],
  518. //>>excludeEnd("ide");
  519. messageSends: []
  520. }),
  521. $globals.Compiler);
  522. $core.addMethod(
  523. $core.method({
  524. selector: "currentPackage:",
  525. protocol: 'accessing',
  526. fn: function (anObject){
  527. var self=this;
  528. self["@currentPackage"]=anObject;
  529. return self;
  530. },
  531. //>>excludeStart("ide", pragmas.excludeIdeData);
  532. args: ["anObject"],
  533. source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
  534. referencedClasses: [],
  535. //>>excludeEnd("ide");
  536. messageSends: []
  537. }),
  538. $globals.Compiler);
  539. $core.addMethod(
  540. $core.method({
  541. selector: "eval:",
  542. protocol: 'compiling',
  543. fn: function (aString){
  544. var self=this;
  545. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  546. return $core.withContext(function($ctx1) {
  547. //>>excludeEnd("ctx");
  548. return eval(aString);
  549. return self;
  550. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  551. }, function($ctx1) {$ctx1.fill(self,"eval:",{aString:aString},$globals.Compiler)});
  552. //>>excludeEnd("ctx");
  553. },
  554. //>>excludeStart("ide", pragmas.excludeIdeData);
  555. args: ["aString"],
  556. source: "eval: aString\x0a\x09<inlineJS: 'return eval(aString)'>",
  557. referencedClasses: [],
  558. //>>excludeEnd("ide");
  559. messageSends: []
  560. }),
  561. $globals.Compiler);
  562. $core.addMethod(
  563. $core.method({
  564. selector: "eval:forPackage:",
  565. protocol: 'compiling',
  566. fn: function (aString,aPackage){
  567. var self=this;
  568. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  569. return $core.withContext(function($ctx1) {
  570. //>>excludeEnd("ctx");
  571. return aPackage && aPackage.innerEval
  572. ? aPackage.innerEval(aString)
  573. : eval(aString);
  574. return self;
  575. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  576. }, function($ctx1) {$ctx1.fill(self,"eval:forPackage:",{aString:aString,aPackage:aPackage},$globals.Compiler)});
  577. //>>excludeEnd("ctx");
  578. },
  579. //>>excludeStart("ide", pragmas.excludeIdeData);
  580. args: ["aString", "aPackage"],
  581. source: "eval: aString forPackage: aPackage\x0a\x09<inlineJS: 'return aPackage && aPackage.innerEval\x0a\x09\x09? aPackage.innerEval(aString)\x0a\x09\x09: eval(aString)'>",
  582. referencedClasses: [],
  583. //>>excludeEnd("ide");
  584. messageSends: []
  585. }),
  586. $globals.Compiler);
  587. $core.addMethod(
  588. $core.method({
  589. selector: "evaluateExpression:",
  590. protocol: 'compiling',
  591. fn: function (aString){
  592. var self=this;
  593. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  594. return $core.withContext(function($ctx1) {
  595. //>>excludeEnd("ctx");
  596. return self._evaluateExpression_on_(aString,$recv($globals.DoIt)._new());
  597. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  598. }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:",{aString:aString},$globals.Compiler)});
  599. //>>excludeEnd("ctx");
  600. },
  601. //>>excludeStart("ide", pragmas.excludeIdeData);
  602. args: ["aString"],
  603. 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",
  604. referencedClasses: ["DoIt"],
  605. //>>excludeEnd("ide");
  606. messageSends: ["evaluateExpression:on:", "new"]
  607. }),
  608. $globals.Compiler);
  609. $core.addMethod(
  610. $core.method({
  611. selector: "evaluateExpression:on:",
  612. protocol: 'compiling',
  613. fn: function (aString,anObject){
  614. var self=this;
  615. var result,method;
  616. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  617. return $core.withContext(function($ctx1) {
  618. //>>excludeEnd("ctx");
  619. var $1;
  620. method=self._eval_(self._compileExpression_on_(aString,anObject));
  621. $recv(method)._protocol_("**xxxDoIt");
  622. $1=$recv(anObject)._class();
  623. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  624. $ctx1.sendIdx["class"]=1;
  625. //>>excludeEnd("ctx");
  626. $recv($1)._addCompiledMethod_(method);
  627. result=$recv(anObject)._xxxDoIt();
  628. $recv($recv(anObject)._class())._removeCompiledMethod_(method);
  629. return result;
  630. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  631. }, function($ctx1) {$ctx1.fill(self,"evaluateExpression:on:",{aString:aString,anObject:anObject,result:result,method:method},$globals.Compiler)});
  632. //>>excludeEnd("ctx");
  633. },
  634. //>>excludeStart("ide", pragmas.excludeIdeData);
  635. args: ["aString", "anObject"],
  636. 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",
  637. referencedClasses: [],
  638. //>>excludeEnd("ide");
  639. messageSends: ["eval:", "compileExpression:on:", "protocol:", "addCompiledMethod:", "class", "xxxDoIt", "removeCompiledMethod:"]
  640. }),
  641. $globals.Compiler);
  642. $core.addMethod(
  643. $core.method({
  644. selector: "install:forClass:protocol:",
  645. protocol: 'compiling',
  646. fn: function (aString,aBehavior,anotherString){
  647. var self=this;
  648. var compiledMethod;
  649. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  650. return $core.withContext(function($ctx1) {
  651. //>>excludeEnd("ctx");
  652. compiledMethod=self._eval_forPackage_(self._compile_forClass_protocol_(aString,aBehavior,anotherString),$recv(aBehavior)._packageOfProtocol_(anotherString));
  653. return $recv($recv($globals.ClassBuilder)._new())._installMethod_forClass_protocol_(compiledMethod,aBehavior,anotherString);
  654. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  655. }, function($ctx1) {$ctx1.fill(self,"install:forClass:protocol:",{aString:aString,aBehavior:aBehavior,anotherString:anotherString,compiledMethod:compiledMethod},$globals.Compiler)});
  656. //>>excludeEnd("ctx");
  657. },
  658. //>>excludeStart("ide", pragmas.excludeIdeData);
  659. args: ["aString", "aBehavior", "anotherString"],
  660. 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",
  661. referencedClasses: ["ClassBuilder"],
  662. //>>excludeEnd("ide");
  663. messageSends: ["eval:forPackage:", "compile:forClass:protocol:", "packageOfProtocol:", "installMethod:forClass:protocol:", "new"]
  664. }),
  665. $globals.Compiler);
  666. $core.addMethod(
  667. $core.method({
  668. selector: "parse:",
  669. protocol: 'compiling',
  670. fn: function (aString){
  671. var self=this;
  672. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  673. return $core.withContext(function($ctx1) {
  674. //>>excludeEnd("ctx");
  675. return $recv($globals.Smalltalk)._parse_(aString);
  676. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  677. }, function($ctx1) {$ctx1.fill(self,"parse:",{aString:aString},$globals.Compiler)});
  678. //>>excludeEnd("ctx");
  679. },
  680. //>>excludeStart("ide", pragmas.excludeIdeData);
  681. args: ["aString"],
  682. source: "parse: aString\x0a\x09^ Smalltalk parse: aString",
  683. referencedClasses: ["Smalltalk"],
  684. //>>excludeEnd("ide");
  685. messageSends: ["parse:"]
  686. }),
  687. $globals.Compiler);
  688. $core.addMethod(
  689. $core.method({
  690. selector: "parseExpression:",
  691. protocol: 'compiling',
  692. fn: function (aString){
  693. var self=this;
  694. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  695. return $core.withContext(function($ctx1) {
  696. //>>excludeEnd("ctx");
  697. var $1;
  698. $1=$recv("doIt ^ [ ".__comma(aString)).__comma(" ] value");
  699. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  700. $ctx1.sendIdx[","]=1;
  701. //>>excludeEnd("ctx");
  702. return self._parse_($1);
  703. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  704. }, function($ctx1) {$ctx1.fill(self,"parseExpression:",{aString:aString},$globals.Compiler)});
  705. //>>excludeEnd("ctx");
  706. },
  707. //>>excludeStart("ide", pragmas.excludeIdeData);
  708. args: ["aString"],
  709. source: "parseExpression: aString\x0a\x09^ self parse: 'doIt ^ [ ', aString, ' ] value'",
  710. referencedClasses: [],
  711. //>>excludeEnd("ide");
  712. messageSends: ["parse:", ","]
  713. }),
  714. $globals.Compiler);
  715. $core.addMethod(
  716. $core.method({
  717. selector: "recompile:",
  718. protocol: 'compiling',
  719. fn: function (aClass){
  720. var self=this;
  721. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  722. return $core.withContext(function($ctx1) {
  723. //>>excludeEnd("ctx");
  724. var $1;
  725. $recv($recv($recv(aClass)._methodDictionary())._values())._do_displayingProgress_((function(each){
  726. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  727. return $core.withContext(function($ctx2) {
  728. //>>excludeEnd("ctx");
  729. return self._install_forClass_protocol_($recv(each)._source(),aClass,$recv(each)._protocol());
  730. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  731. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  732. //>>excludeEnd("ctx");
  733. }),"Recompiling ".__comma($recv(aClass)._name()));
  734. $1=$recv(aClass)._isMetaclass();
  735. if(!$core.assert($1)){
  736. self._recompile_($recv(aClass)._class());
  737. }
  738. return self;
  739. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  740. }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler)});
  741. //>>excludeEnd("ctx");
  742. },
  743. //>>excludeStart("ide", pragmas.excludeIdeData);
  744. args: ["aClass"],
  745. 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 ]",
  746. referencedClasses: [],
  747. //>>excludeEnd("ide");
  748. messageSends: ["do:displayingProgress:", "values", "methodDictionary", "install:forClass:protocol:", "source", "protocol", ",", "name", "ifFalse:", "isMetaclass", "recompile:", "class"]
  749. }),
  750. $globals.Compiler);
  751. $core.addMethod(
  752. $core.method({
  753. selector: "recompileAll",
  754. protocol: 'compiling',
  755. fn: function (){
  756. var self=this;
  757. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  758. return $core.withContext(function($ctx1) {
  759. //>>excludeEnd("ctx");
  760. $recv($recv($globals.Smalltalk)._classes())._do_displayingProgress_((function(each){
  761. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  762. return $core.withContext(function($ctx2) {
  763. //>>excludeEnd("ctx");
  764. return self._recompile_(each);
  765. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  766. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  767. //>>excludeEnd("ctx");
  768. }),"Compiling all classes...");
  769. return self;
  770. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  771. }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler)});
  772. //>>excludeEnd("ctx");
  773. },
  774. //>>excludeStart("ide", pragmas.excludeIdeData);
  775. args: [],
  776. source: "recompileAll\x0a\x09Smalltalk classes \x0a\x09\x09do: [ :each | self recompile: each ]\x0a\x09\x09displayingProgress: 'Compiling all classes...'",
  777. referencedClasses: ["Smalltalk"],
  778. //>>excludeEnd("ide");
  779. messageSends: ["do:displayingProgress:", "classes", "recompile:"]
  780. }),
  781. $globals.Compiler);
  782. $core.addMethod(
  783. $core.method({
  784. selector: "source",
  785. protocol: 'accessing',
  786. fn: function (){
  787. var self=this;
  788. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  789. return $core.withContext(function($ctx1) {
  790. //>>excludeEnd("ctx");
  791. var $1,$receiver;
  792. $1=self["@source"];
  793. if(($receiver = $1) == null || $receiver.isNil){
  794. return "";
  795. } else {
  796. return $1;
  797. }
  798. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  799. }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.Compiler)});
  800. //>>excludeEnd("ctx");
  801. },
  802. //>>excludeStart("ide", pragmas.excludeIdeData);
  803. args: [],
  804. source: "source\x0a\x09^ source ifNil: [ '' ]",
  805. referencedClasses: [],
  806. //>>excludeEnd("ide");
  807. messageSends: ["ifNil:"]
  808. }),
  809. $globals.Compiler);
  810. $core.addMethod(
  811. $core.method({
  812. selector: "source:",
  813. protocol: 'accessing',
  814. fn: function (aString){
  815. var self=this;
  816. self["@source"]=aString;
  817. return self;
  818. },
  819. //>>excludeStart("ide", pragmas.excludeIdeData);
  820. args: ["aString"],
  821. source: "source: aString\x0a\x09source := aString",
  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 (){
  832. var self=this;
  833. return self["@unknownVariables"];
  834. },
  835. //>>excludeStart("ide", pragmas.excludeIdeData);
  836. args: [],
  837. source: "unknownVariables\x0a\x09^ unknownVariables",
  838. referencedClasses: [],
  839. //>>excludeEnd("ide");
  840. messageSends: []
  841. }),
  842. $globals.Compiler);
  843. $core.addMethod(
  844. $core.method({
  845. selector: "unknownVariables:",
  846. protocol: 'accessing',
  847. fn: function (aCollection){
  848. var self=this;
  849. self["@unknownVariables"]=aCollection;
  850. return self;
  851. },
  852. //>>excludeStart("ide", pragmas.excludeIdeData);
  853. args: ["aCollection"],
  854. source: "unknownVariables: aCollection\x0a\x09unknownVariables := aCollection",
  855. referencedClasses: [],
  856. //>>excludeEnd("ide");
  857. messageSends: []
  858. }),
  859. $globals.Compiler);
  860. $core.addMethod(
  861. $core.method({
  862. selector: "recompile:",
  863. protocol: 'compiling',
  864. fn: function (aClass){
  865. var self=this;
  866. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  867. return $core.withContext(function($ctx1) {
  868. //>>excludeEnd("ctx");
  869. $recv(self._new())._recompile_(aClass);
  870. return self;
  871. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  872. }, function($ctx1) {$ctx1.fill(self,"recompile:",{aClass:aClass},$globals.Compiler.klass)});
  873. //>>excludeEnd("ctx");
  874. },
  875. //>>excludeStart("ide", pragmas.excludeIdeData);
  876. args: ["aClass"],
  877. source: "recompile: aClass\x0a\x09self new recompile: aClass",
  878. referencedClasses: [],
  879. //>>excludeEnd("ide");
  880. messageSends: ["recompile:", "new"]
  881. }),
  882. $globals.Compiler.klass);
  883. $core.addMethod(
  884. $core.method({
  885. selector: "recompileAll",
  886. protocol: 'compiling',
  887. fn: function (){
  888. var self=this;
  889. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  890. return $core.withContext(function($ctx1) {
  891. //>>excludeEnd("ctx");
  892. $recv($recv($globals.Smalltalk)._classes())._do_((function(each){
  893. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  894. return $core.withContext(function($ctx2) {
  895. //>>excludeEnd("ctx");
  896. return self._recompile_(each);
  897. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  898. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1,1)});
  899. //>>excludeEnd("ctx");
  900. }));
  901. return self;
  902. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  903. }, function($ctx1) {$ctx1.fill(self,"recompileAll",{},$globals.Compiler.klass)});
  904. //>>excludeEnd("ctx");
  905. },
  906. //>>excludeStart("ide", pragmas.excludeIdeData);
  907. args: [],
  908. source: "recompileAll\x0a\x09Smalltalk classes do: [ :each |\x0a\x09\x09self recompile: each ]",
  909. referencedClasses: ["Smalltalk"],
  910. //>>excludeEnd("ide");
  911. messageSends: ["do:", "classes", "recompile:"]
  912. }),
  913. $globals.Compiler.klass);
  914. $core.addClass('CompilerError', $globals.Error, [], 'Compiler-Core');
  915. //>>excludeStart("ide", pragmas.excludeIdeData);
  916. $globals.CompilerError.comment="I am the common superclass of all compiling errors.";
  917. //>>excludeEnd("ide");
  918. $core.addClass('DoIt', $globals.Object, [], 'Compiler-Core');
  919. //>>excludeStart("ide", pragmas.excludeIdeData);
  920. $globals.DoIt.comment="`DoIt` is the class used to compile and evaluate expressions. See `Compiler >> evaluateExpression:`.";
  921. //>>excludeEnd("ide");
  922. $core.addClass('Evaluator', $globals.Object, [], 'Compiler-Core');
  923. //>>excludeStart("ide", pragmas.excludeIdeData);
  924. $globals.Evaluator.comment="I evaluate code against a receiver, dispatching #evaluate:on: to the receiver.";
  925. //>>excludeEnd("ide");
  926. $core.addMethod(
  927. $core.method({
  928. selector: "evaluate:context:",
  929. protocol: 'evaluating',
  930. fn: function (aString,aContext){
  931. var self=this;
  932. var compiler,ast;
  933. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  934. return $core.withContext(function($ctx1) {
  935. //>>excludeEnd("ctx");
  936. var $1;
  937. var $early={};
  938. try {
  939. compiler=$recv($globals.Compiler)._new();
  940. $recv((function(){
  941. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  942. return $core.withContext(function($ctx2) {
  943. //>>excludeEnd("ctx");
  944. ast=$recv(compiler)._parseExpression_(aString);
  945. return ast;
  946. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  947. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  948. //>>excludeEnd("ctx");
  949. }))._on_do_($globals.Error,(function(ex){
  950. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  951. return $core.withContext(function($ctx2) {
  952. //>>excludeEnd("ctx");
  953. throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
  954. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  955. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
  956. //>>excludeEnd("ctx");
  957. }));
  958. $1=$recv($globals.AISemanticAnalyzer)._on_($recv($recv(aContext)._receiver())._class());
  959. $recv($1)._context_(aContext);
  960. $recv($1)._visit_(ast);
  961. return $recv(aContext)._evaluateNode_(ast);
  962. }
  963. catch(e) {if(e===$early)return e[0]; throw e}
  964. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  965. }, function($ctx1) {$ctx1.fill(self,"evaluate:context:",{aString:aString,aContext:aContext,compiler:compiler,ast:ast},$globals.Evaluator)});
  966. //>>excludeEnd("ctx");
  967. },
  968. //>>excludeStart("ide", pragmas.excludeIdeData);
  969. args: ["aString", "aContext"],
  970. 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",
  971. referencedClasses: ["Compiler", "Error", "Terminal", "AISemanticAnalyzer"],
  972. //>>excludeEnd("ide");
  973. messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "context:", "on:", "class", "receiver", "visit:", "evaluateNode:"]
  974. }),
  975. $globals.Evaluator);
  976. $core.addMethod(
  977. $core.method({
  978. selector: "evaluate:for:",
  979. protocol: 'evaluating',
  980. fn: function (aString,anObject){
  981. var self=this;
  982. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  983. return $core.withContext(function($ctx1) {
  984. //>>excludeEnd("ctx");
  985. return $recv(anObject)._evaluate_on_(aString,self);
  986. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  987. }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator)});
  988. //>>excludeEnd("ctx");
  989. },
  990. //>>excludeStart("ide", pragmas.excludeIdeData);
  991. args: ["aString", "anObject"],
  992. source: "evaluate: aString for: anObject\x0a\x09^ anObject evaluate: aString on: self",
  993. referencedClasses: [],
  994. //>>excludeEnd("ide");
  995. messageSends: ["evaluate:on:"]
  996. }),
  997. $globals.Evaluator);
  998. $core.addMethod(
  999. $core.method({
  1000. selector: "evaluate:receiver:",
  1001. protocol: 'evaluating',
  1002. fn: function (aString,anObject){
  1003. var self=this;
  1004. var compiler;
  1005. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1006. return $core.withContext(function($ctx1) {
  1007. //>>excludeEnd("ctx");
  1008. var $early={};
  1009. try {
  1010. compiler=$recv($globals.Compiler)._new();
  1011. $recv((function(){
  1012. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1013. return $core.withContext(function($ctx2) {
  1014. //>>excludeEnd("ctx");
  1015. return $recv(compiler)._parseExpression_(aString);
  1016. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1017. }, function($ctx2) {$ctx2.fillBlock({},$ctx1,1)});
  1018. //>>excludeEnd("ctx");
  1019. }))._on_do_($globals.Error,(function(ex){
  1020. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1021. return $core.withContext(function($ctx2) {
  1022. //>>excludeEnd("ctx");
  1023. throw $early=[$recv($globals.Terminal)._alert_($recv(ex)._messageText())];
  1024. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1025. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1,2)});
  1026. //>>excludeEnd("ctx");
  1027. }));
  1028. return $recv(compiler)._evaluateExpression_on_(aString,anObject);
  1029. }
  1030. catch(e) {if(e===$early)return e[0]; throw e}
  1031. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1032. }, function($ctx1) {$ctx1.fill(self,"evaluate:receiver:",{aString:aString,anObject:anObject,compiler:compiler},$globals.Evaluator)});
  1033. //>>excludeEnd("ctx");
  1034. },
  1035. //>>excludeStart("ide", pragmas.excludeIdeData);
  1036. args: ["aString", "anObject"],
  1037. 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",
  1038. referencedClasses: ["Compiler", "Error", "Terminal"],
  1039. //>>excludeEnd("ide");
  1040. messageSends: ["new", "on:do:", "parseExpression:", "alert:", "messageText", "evaluateExpression:on:"]
  1041. }),
  1042. $globals.Evaluator);
  1043. $core.addMethod(
  1044. $core.method({
  1045. selector: "evaluate:for:",
  1046. protocol: 'instance creation',
  1047. fn: function (aString,anObject){
  1048. var self=this;
  1049. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1050. return $core.withContext(function($ctx1) {
  1051. //>>excludeEnd("ctx");
  1052. return $recv(self._new())._evaluate_for_(aString,anObject);
  1053. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1054. }, function($ctx1) {$ctx1.fill(self,"evaluate:for:",{aString:aString,anObject:anObject},$globals.Evaluator.klass)});
  1055. //>>excludeEnd("ctx");
  1056. },
  1057. //>>excludeStart("ide", pragmas.excludeIdeData);
  1058. args: ["aString", "anObject"],
  1059. source: "evaluate: aString for: anObject\x0a\x09^ self new evaluate: aString for: anObject",
  1060. referencedClasses: [],
  1061. //>>excludeEnd("ide");
  1062. messageSends: ["evaluate:for:", "new"]
  1063. }),
  1064. $globals.Evaluator.klass);
  1065. $core.addMethod(
  1066. $core.method({
  1067. selector: "asVariableName",
  1068. protocol: '*Compiler-Core',
  1069. fn: function (){
  1070. var self=this;
  1071. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1072. return $core.withContext(function($ctx1) {
  1073. //>>excludeEnd("ctx");
  1074. var $1;
  1075. $1=$recv($recv($globals.Smalltalk)._reservedWords())._includes_(self);
  1076. if($core.assert($1)){
  1077. return self.__comma("_");
  1078. } else {
  1079. return self;
  1080. }
  1081. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  1082. }, function($ctx1) {$ctx1.fill(self,"asVariableName",{},$globals.String)});
  1083. //>>excludeEnd("ctx");
  1084. },
  1085. //>>excludeStart("ide", pragmas.excludeIdeData);
  1086. args: [],
  1087. source: "asVariableName\x0a\x09^ (Smalltalk reservedWords includes: self)\x0a\x09\x09ifTrue: [ self, '_' ]\x0a\x09\x09ifFalse: [ self ]",
  1088. referencedClasses: ["Smalltalk"],
  1089. //>>excludeEnd("ide");
  1090. messageSends: ["ifTrue:ifFalse:", "includes:", "reservedWords", ","]
  1091. }),
  1092. $globals.String);
  1093. });