Compiler-Core.js 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158
  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: "classNameFor:",
  13. protocol: 'accessing',
  14. fn: function (aClass){
  15. var self=this;
  16. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  17. return $core.withContext(function($ctx1) {
  18. //>>excludeEnd("ctx");
  19. var $2,$3,$4,$1;
  20. $2=$recv(aClass)._isMetaclass();
  21. if($core.assert($2)){
  22. $3=$recv($recv(aClass)._instanceClass())._name();
  23. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  24. $ctx1.sendIdx["name"]=1;
  25. //>>excludeEnd("ctx");
  26. $1=$recv($3).__comma(".klass");
  27. } else {
  28. $4=$recv(aClass)._isNil();
  29. if($core.assert($4)){
  30. $1="nil";
  31. } else {
  32. $1=$recv(aClass)._name();
  33. };
  34. };
  35. return $1;
  36. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  37. }, function($ctx1) {$ctx1.fill(self,"classNameFor:",{aClass:aClass},$globals.AbstractCodeGenerator)});
  38. //>>excludeEnd("ctx");
  39. },
  40. //>>excludeStart("ide", pragmas.excludeIdeData);
  41. args: ["aClass"],
  42. source: "classNameFor: aClass\x0a\x09^ aClass isMetaclass\x0a\x09\x09ifTrue: [ aClass instanceClass name, '.klass' ]\x0a\x09\x09ifFalse: [\x0a\x09\x09aClass isNil\x0a\x09\x09\x09ifTrue: [ 'nil' ]\x0a\x09\x09\x09ifFalse: [ aClass name ]]",
  43. referencedClasses: [],
  44. //>>excludeEnd("ide");
  45. messageSends: ["ifTrue:ifFalse:", "isMetaclass", ",", "name", "instanceClass", "isNil"]
  46. }),
  47. $globals.AbstractCodeGenerator);
  48. $core.addMethod(
  49. $core.method({
  50. selector: "compileNode:",
  51. protocol: 'compiling',
  52. fn: function (aNode){
  53. var self=this;
  54. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  55. return $core.withContext(function($ctx1) {
  56. //>>excludeEnd("ctx");
  57. self._subclassResponsibility();
  58. return self;
  59. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  60. }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode},$globals.AbstractCodeGenerator)});
  61. //>>excludeEnd("ctx");
  62. },
  63. //>>excludeStart("ide", pragmas.excludeIdeData);
  64. args: ["aNode"],
  65. source: "compileNode: aNode\x0a\x09self subclassResponsibility",
  66. referencedClasses: [],
  67. //>>excludeEnd("ide");
  68. messageSends: ["subclassResponsibility"]
  69. }),
  70. $globals.AbstractCodeGenerator);
  71. $core.addMethod(
  72. $core.method({
  73. selector: "currentClass",
  74. protocol: 'accessing',
  75. fn: function (){
  76. var self=this;
  77. return self["@currentClass"];
  78. },
  79. //>>excludeStart("ide", pragmas.excludeIdeData);
  80. args: [],
  81. source: "currentClass\x0a\x09^ currentClass",
  82. referencedClasses: [],
  83. //>>excludeEnd("ide");
  84. messageSends: []
  85. }),
  86. $globals.AbstractCodeGenerator);
  87. $core.addMethod(
  88. $core.method({
  89. selector: "currentClass:",
  90. protocol: 'accessing',
  91. fn: function (aClass){
  92. var self=this;
  93. self["@currentClass"]=aClass;
  94. return self;
  95. },
  96. //>>excludeStart("ide", pragmas.excludeIdeData);
  97. args: ["aClass"],
  98. source: "currentClass: aClass\x0a\x09currentClass := aClass",
  99. referencedClasses: [],
  100. //>>excludeEnd("ide");
  101. messageSends: []
  102. }),
  103. $globals.AbstractCodeGenerator);
  104. $core.addMethod(
  105. $core.method({
  106. selector: "currentPackage",
  107. protocol: 'accessing',
  108. fn: function (){
  109. var self=this;
  110. return self["@currentPackage"];
  111. },
  112. //>>excludeStart("ide", pragmas.excludeIdeData);
  113. args: [],
  114. source: "currentPackage\x0a\x09^ currentPackage",
  115. referencedClasses: [],
  116. //>>excludeEnd("ide");
  117. messageSends: []
  118. }),
  119. $globals.AbstractCodeGenerator);
  120. $core.addMethod(
  121. $core.method({
  122. selector: "currentPackage:",
  123. protocol: 'accessing',
  124. fn: function (anObject){
  125. var self=this;
  126. self["@currentPackage"]=anObject;
  127. return self;
  128. },
  129. //>>excludeStart("ide", pragmas.excludeIdeData);
  130. args: ["anObject"],
  131. source: "currentPackage: anObject\x0a\x09currentPackage := anObject",
  132. referencedClasses: [],
  133. //>>excludeEnd("ide");
  134. messageSends: []
  135. }),
  136. $globals.AbstractCodeGenerator);
  137. $core.addMethod(
  138. $core.method({
  139. selector: "pseudoVariables",
  140. protocol: 'accessing',
  141. fn: function (){
  142. var self=this;
  143. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  144. return $core.withContext(function($ctx1) {
  145. //>>excludeEnd("ctx");
  146. return $recv($globals.Smalltalk)._pseudoVariableNames();
  147. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  148. }, function($ctx1) {$ctx1.fill(self,"pseudoVariables",{},$globals.AbstractCodeGenerator)});
  149. //>>excludeEnd("ctx");
  150. },
  151. //>>excludeStart("ide", pragmas.excludeIdeData);
  152. args: [],
  153. source: "pseudoVariables\x0a\x09^ Smalltalk pseudoVariableNames",
  154. referencedClasses: ["Smalltalk"],
  155. //>>excludeEnd("ide");
  156. messageSends: ["pseudoVariableNames"]
  157. }),
  158. $globals.AbstractCodeGenerator);
  159. $core.addMethod(
  160. $core.method({
  161. selector: "source",
  162. protocol: 'accessing',
  163. fn: function (){
  164. var self=this;
  165. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  166. return $core.withContext(function($ctx1) {
  167. //>>excludeEnd("ctx");
  168. var $1,$receiver;
  169. $1=self["@source"];
  170. if(($receiver = $1) == null || $receiver.isNil){
  171. return "";
  172. } else {
  173. return $1;
  174. };
  175. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  176. }, function($ctx1) {$ctx1.fill(self,"source",{},$globals.AbstractCodeGenerator)});
  177. //>>excludeEnd("ctx");
  178. },
  179. //>>excludeStart("ide", pragmas.excludeIdeData);
  180. args: [],
  181. source: "source\x0a\x09^ source ifNil: [ '' ]",
  182. referencedClasses: [],
  183. //>>excludeEnd("ide");
  184. messageSends: ["ifNil:"]
  185. }),
  186. $globals.AbstractCodeGenerator);
  187. $core.addMethod(
  188. $core.method({
  189. selector: "source:",
  190. protocol: 'accessing',
  191. fn: function (aString){
  192. var self=this;
  193. self["@source"]=aString;
  194. return self;
  195. },
  196. //>>excludeStart("ide", pragmas.excludeIdeData);
  197. args: ["aString"],
  198. source: "source: aString\x0a\x09source := aString",
  199. referencedClasses: [],
  200. //>>excludeEnd("ide");
  201. messageSends: []
  202. }),
  203. $globals.AbstractCodeGenerator);
  204. $core.addClass('CodeGenerator', $globals.AbstractCodeGenerator, [], 'Compiler-Core');
  205. //>>excludeStart("ide", pragmas.excludeIdeData);
  206. $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.";
  207. //>>excludeEnd("ide");
  208. $core.addMethod(
  209. $core.method({
  210. selector: "compileNode:",
  211. protocol: 'compiling',
  212. fn: function (aNode){
  213. var self=this;
  214. var ir,stream;
  215. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  216. return $core.withContext(function($ctx1) {
  217. //>>excludeEnd("ctx");
  218. var $1;
  219. $recv(self._semanticAnalyzer())._visit_(aNode);
  220. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  221. $ctx1.sendIdx["visit:"]=1;
  222. //>>excludeEnd("ctx");
  223. ir=$recv(self._translator())._visit_(aNode);
  224. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  225. $ctx1.sendIdx["visit:"]=2;
  226. //>>excludeEnd("ctx");
  227. $1=self._irTranslator();
  228. $recv($1)._currentClass_(self._currentClass());
  229. $recv($1)._visit_(ir);
  230. return $recv($1)._contents();
  231. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  232. }, function($ctx1) {$ctx1.fill(self,"compileNode:",{aNode:aNode,ir:ir,stream:stream},$globals.CodeGenerator)});
  233. //>>excludeEnd("ctx");
  234. },
  235. //>>excludeStart("ide", pragmas.excludeIdeData);
  236. args: ["aNode"],
  237. 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",
  238. referencedClasses: [],
  239. //>>excludeEnd("ide");
  240. messageSends: ["visit:", "semanticAnalyzer", "translator", "currentClass:", "irTranslator", "currentClass", "contents"]
  241. }),
  242. $globals.CodeGenerator);
  243. $core.addMethod(
  244. $core.method({
  245. selector: "irTranslator",
  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. return $recv($globals.IRJSTranslator)._new();
  253. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  254. }, function($ctx1) {$ctx1.fill(self,"irTranslator",{},$globals.CodeGenerator)});
  255. //>>excludeEnd("ctx");
  256. },
  257. //>>excludeStart("ide", pragmas.excludeIdeData);
  258. args: [],
  259. source: "irTranslator\x0a\x09^ IRJSTranslator new",
  260. referencedClasses: ["IRJSTranslator"],
  261. //>>excludeEnd("ide");
  262. messageSends: ["new"]
  263. }),
  264. $globals.CodeGenerator);
  265. $core.addMethod(
  266. $core.method({
  267. selector: "semanticAnalyzer",
  268. protocol: 'compiling',
  269. fn: function (){
  270. var self=this;
  271. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  272. return $core.withContext(function($ctx1) {
  273. //>>excludeEnd("ctx");
  274. var $1;
  275. $1=$recv($globals.SemanticAnalyzer)._on_(self._currentClass());
  276. $recv($1)._thePackage_(self._currentPackage());
  277. return $recv($1)._yourself();
  278. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  279. }, function($ctx1) {$ctx1.fill(self,"semanticAnalyzer",{},$globals.CodeGenerator)});
  280. //>>excludeEnd("ctx");
  281. },
  282. //>>excludeStart("ide", pragmas.excludeIdeData);
  283. args: [],
  284. source: "semanticAnalyzer\x0a\x09^ (SemanticAnalyzer on: self currentClass)\x0a\x09\x09thePackage: self currentPackage;\x0a\x09\x09yourself",
  285. referencedClasses: ["SemanticAnalyzer"],
  286. //>>excludeEnd("ide");
  287. messageSends: ["thePackage:", "on:", "currentClass", "currentPackage", "yourself"]
  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<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<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.InterfacingObject, [], '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=[self._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 | ^ 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",
  968. referencedClasses: ["Compiler", "Error", "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=[self._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 | ^ self alert: ex messageText ].\x0a\x0a\x09^ compiler evaluateExpression: aString on: anObject",
  1035. referencedClasses: ["Compiler", "Error"],
  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. });