Compiler-Core.js 38 KB

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