Compiler-Core.js 39 KB

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