Helios-Environments.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. smalltalk.addPackage('Helios-Environments');
  2. smalltalk.addClass('HLEnvironment', smalltalk.Object, [], 'Helios-Environments');
  3. smalltalk.HLEnvironment.comment="Abstract class defining common behavior for local and remote environments"
  4. smalltalk.addMethod(
  5. "_addInstVarNamed_to_",
  6. smalltalk.method({
  7. selector: "addInstVarNamed:to:",
  8. category: 'compiling',
  9. fn: function (aString,aClass){
  10. var self=this;
  11. return smalltalk.withContext(function($ctx1) { var $1,$2;
  12. $1=_st(_st(aClass)._instanceVariableNames())._copy();
  13. _st($1)._add_(aString);
  14. $2=_st($1)._yourself();
  15. _st(_st(self)._classBuilder())._addSubclassOf_named_instanceVariableNames_package_(_st(aClass)._superclass(),_st(aClass)._name(),$2,_st(_st(aClass)._package())._name());
  16. return self}, function($ctx1) {$ctx1.fill(self,"addInstVarNamed:to:",{aString:aString,aClass:aClass}, smalltalk.HLEnvironment)})},
  17. args: ["aString", "aClass"],
  18. source: "addInstVarNamed: aString to: aClass\x0a\x09self classBuilder\x0a\x09\x09addSubclassOf: aClass superclass \x0a\x09\x09named: aClass name \x0a\x09\x09instanceVariableNames: (aClass instanceVariableNames copy add: aString; yourself)\x0a\x09\x09package: aClass package name",
  19. messageSends: ["addSubclassOf:named:instanceVariableNames:package:", "superclass", "name", "add:", "copy", "instanceVariableNames", "yourself", "package", "classBuilder"],
  20. referencedClasses: []
  21. }),
  22. smalltalk.HLEnvironment);
  23. smalltalk.addMethod(
  24. "_availableClassNames",
  25. smalltalk.method({
  26. selector: "availableClassNames",
  27. category: 'accessing',
  28. fn: function (){
  29. var self=this;
  30. return smalltalk.withContext(function($ctx1) { _st(self)._subclassResponsibility();
  31. return self}, function($ctx1) {$ctx1.fill(self,"availableClassNames",{},smalltalk.HLEnvironment)})},
  32. args: [],
  33. source: "availableClassNames\x0a\x09self subclassResponsibility",
  34. messageSends: ["subclassResponsibility"],
  35. referencedClasses: []
  36. }),
  37. smalltalk.HLEnvironment);
  38. smalltalk.addMethod(
  39. "_availableProtocolsFor_",
  40. smalltalk.method({
  41. selector: "availableProtocolsFor:",
  42. category: 'accessing',
  43. fn: function (aClass){
  44. var self=this;
  45. return smalltalk.withContext(function($ctx1) { _st(self)._subclassResponsibility();
  46. return self}, function($ctx1) {$ctx1.fill(self,"availableProtocolsFor:",{aClass:aClass},smalltalk.HLEnvironment)})},
  47. args: ["aClass"],
  48. source: "availableProtocolsFor: aClass\x0a\x09self subclassResponsibility",
  49. messageSends: ["subclassResponsibility"],
  50. referencedClasses: []
  51. }),
  52. smalltalk.HLEnvironment);
  53. smalltalk.addMethod(
  54. "_classBuilder",
  55. smalltalk.method({
  56. selector: "classBuilder",
  57. category: 'accessing',
  58. fn: function (){
  59. var self=this;
  60. return smalltalk.withContext(function($ctx1) { var $1;
  61. $1=_st(self)._subclassResponsibility();
  62. return $1;
  63. }, function($ctx1) {$ctx1.fill(self,"classBuilder",{}, smalltalk.HLEnvironment)})},
  64. args: [],
  65. source: "classBuilder\x0a\x09^ self subclassResponsibility",
  66. messageSends: ["subclassResponsibility"],
  67. referencedClasses: []
  68. }),
  69. smalltalk.HLEnvironment);
  70. smalltalk.addMethod(
  71. "_compileClassComment_for_",
  72. smalltalk.method({
  73. selector: "compileClassComment:for:",
  74. category: 'compiling',
  75. fn: function (aString,aClass){
  76. var self=this;
  77. return smalltalk.withContext(function($ctx1) { _st(aClass)._comment_(aString);
  78. return self}, function($ctx1) {$ctx1.fill(self,"compileClassComment:for:",{aString:aString,aClass:aClass}, smalltalk.HLEnvironment)})},
  79. args: ["aString", "aClass"],
  80. source: "compileClassComment: aString for: aClass\x0a\x09aClass comment: aString",
  81. messageSends: ["comment:"],
  82. referencedClasses: []
  83. }),
  84. smalltalk.HLEnvironment);
  85. smalltalk.addMethod(
  86. "_compileClassDefinition_",
  87. smalltalk.method({
  88. selector: "compileClassDefinition:",
  89. category: 'compiling',
  90. fn: function (aString){
  91. var self=this;
  92. return smalltalk.withContext(function($ctx1) { _st(self)._eval_on_(aString,_st((smalltalk.DoIt || DoIt))._new());
  93. return self}, function($ctx1) {$ctx1.fill(self,"compileClassDefinition:",{aString:aString}, smalltalk.HLEnvironment)})},
  94. args: ["aString"],
  95. source: "compileClassDefinition: aString\x0a\x09self eval: aString on: DoIt new",
  96. messageSends: ["eval:on:", "new"],
  97. referencedClasses: ["DoIt"]
  98. }),
  99. smalltalk.HLEnvironment);
  100. smalltalk.addMethod(
  101. "_compileMethod_for_protocol_",
  102. smalltalk.method({
  103. selector: "compileMethod:for:protocol:",
  104. category: 'compiling',
  105. fn: function (sourceCode,class_,protocol){
  106. var self=this;
  107. return smalltalk.withContext(function($ctx1) { _st(class_)._compile_category_(sourceCode,protocol);
  108. return self}, function($ctx1) {$ctx1.fill(self,"compileMethod:for:protocol:",{sourceCode:sourceCode,class_:class_,protocol:protocol}, smalltalk.HLEnvironment)})},
  109. args: ["sourceCode", "class", "protocol"],
  110. source: "compileMethod: sourceCode for: class protocol: protocol\x0a\x09class\x0a\x09\x09compile: sourceCode\x0a\x09\x09category: protocol",
  111. messageSends: ["compile:category:"],
  112. referencedClasses: []
  113. }),
  114. smalltalk.HLEnvironment);
  115. smalltalk.addMethod(
  116. "_eval_on_",
  117. smalltalk.method({
  118. selector: "eval:on:",
  119. category: 'actions',
  120. fn: function (someCode,aReceiver){
  121. var self=this;
  122. return smalltalk.withContext(function($ctx1) { var $1;
  123. $1=_st(self)._subclassResponsibility();
  124. return $1;
  125. }, function($ctx1) {$ctx1.fill(self,"eval:on:",{someCode:someCode,aReceiver:aReceiver}, smalltalk.HLEnvironment)})},
  126. args: ["someCode", "aReceiver"],
  127. source: "eval: someCode on: aReceiver\x0a\x0a\x09^ self subclassResponsibility",
  128. messageSends: ["subclassResponsibility"],
  129. referencedClasses: []
  130. }),
  131. smalltalk.HLEnvironment);
  132. smalltalk.addMethod(
  133. "_moveMethod_toClass_",
  134. smalltalk.method({
  135. selector: "moveMethod:toClass:",
  136. category: 'actions',
  137. fn: function (aMethod,aClassName){
  138. var self=this;
  139. return smalltalk.withContext(function($ctx1) { _st(self)._subclassResponsibility();
  140. return self}, function($ctx1) {$ctx1.fill(self,"moveMethod:toClass:",{aMethod:aMethod,aClassName:aClassName},smalltalk.HLEnvironment)})},
  141. args: ["aMethod", "aClassName"],
  142. source: "moveMethod: aMethod toClass: aClassName\x0a\x09self subclassResponsibility",
  143. messageSends: ["subclassResponsibility"],
  144. referencedClasses: []
  145. }),
  146. smalltalk.HLEnvironment);
  147. smalltalk.addMethod(
  148. "_packages",
  149. smalltalk.method({
  150. selector: "packages",
  151. category: 'accessing',
  152. fn: function (){
  153. var self=this;
  154. return smalltalk.withContext(function($ctx1) { var $1;
  155. $1=_st(self)._subclassResponsibility();
  156. return $1;
  157. }, function($ctx1) {$ctx1.fill(self,"packages",{}, smalltalk.HLEnvironment)})},
  158. args: [],
  159. source: "packages\x0a\x09^ self subclassResponsibility",
  160. messageSends: ["subclassResponsibility"],
  161. referencedClasses: []
  162. }),
  163. smalltalk.HLEnvironment);
  164. smalltalk.addClass('HLLocalEnvironment', smalltalk.HLEnvironment, [], 'Helios-Environments');
  165. smalltalk.addMethod(
  166. "_availableClassNames",
  167. smalltalk.method({
  168. selector: "availableClassNames",
  169. category: 'accessing',
  170. fn: function (){
  171. var self=this;
  172. return smalltalk.withContext(function($ctx1) { var $1;
  173. $1=_st(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes())._collect_((function(each){
  174. return smalltalk.withContext(function($ctx2) { return _st(each)._name();
  175. }, function($ctx2) {$ctx2.fillBlock({each:each},$ctx1)})}));
  176. return $1;
  177. }, function($ctx1) {$ctx1.fill(self,"availableClassNames",{},smalltalk.HLLocalEnvironment)})},
  178. args: [],
  179. source: "availableClassNames\x0a\x09^ Smalltalk current classes \x0a\x09\x09collect: [ :each | each name ]",
  180. messageSends: ["collect:", "name", "classes", "current"],
  181. referencedClasses: ["Smalltalk"]
  182. }),
  183. smalltalk.HLLocalEnvironment);
  184. smalltalk.addMethod(
  185. "_availableProtocolsFor_",
  186. smalltalk.method({
  187. selector: "availableProtocolsFor:",
  188. category: 'accessing',
  189. fn: function (aClass){
  190. var self=this;
  191. var protocols;
  192. return smalltalk.withContext(function($ctx1) { var $1,$2;
  193. protocols=_st(aClass)._protocols();
  194. $1=_st(aClass)._superclass();
  195. if(($receiver = $1) == nil || $receiver == undefined){
  196. $1;
  197. } else {
  198. _st(protocols)._addAll_(_st(self)._availableProtocolsFor_(_st(aClass)._superclass()));
  199. };
  200. $2=_st(_st(protocols)._asSet())._asArray();
  201. return $2;
  202. }, function($ctx1) {$ctx1.fill(self,"availableProtocolsFor:",{aClass:aClass,protocols:protocols},smalltalk.HLLocalEnvironment)})},
  203. args: ["aClass"],
  204. source: "availableProtocolsFor: aClass\x0a\x09| protocols |\x0a\x09\x0a\x09protocols := aClass protocols.\x0a\x09aClass superclass ifNotNil: [ protocols addAll: (self availableProtocolsFor: aClass superclass) ].\x0a\x09^ protocols asSet asArray",
  205. messageSends: ["protocols", "ifNotNil:", "addAll:", "availableProtocolsFor:", "superclass", "asArray", "asSet"],
  206. referencedClasses: []
  207. }),
  208. smalltalk.HLLocalEnvironment);
  209. smalltalk.addMethod(
  210. "_classBuilder",
  211. smalltalk.method({
  212. selector: "classBuilder",
  213. category: 'accessing',
  214. fn: function (){
  215. var self=this;
  216. return smalltalk.withContext(function($ctx1) { var $1;
  217. $1=_st((smalltalk.ClassBuilder || ClassBuilder))._new();
  218. return $1;
  219. }, function($ctx1) {$ctx1.fill(self,"classBuilder",{}, smalltalk.HLLocalEnvironment)})},
  220. args: [],
  221. source: "classBuilder\x0a\x09^ ClassBuilder new",
  222. messageSends: ["new"],
  223. referencedClasses: ["ClassBuilder"]
  224. }),
  225. smalltalk.HLLocalEnvironment);
  226. smalltalk.addMethod(
  227. "_eval_on_",
  228. smalltalk.method({
  229. selector: "eval:on:",
  230. category: 'actions',
  231. fn: function (aString,aReceiver){
  232. var self=this;
  233. var compiler;
  234. return smalltalk.withContext(function($ctx1) { var $1,$2;
  235. var $early={};
  236. try {
  237. compiler=_st((smalltalk.Compiler || Compiler))._new();
  238. _st((function(){
  239. return smalltalk.withContext(function($ctx2) { return _st(compiler)._parseExpression_(aString);
  240. }, function($ctx2) {$ctx2.fillBlock({},$ctx1)})}))._on_do_((smalltalk.Error || Error),(function(ex){
  241. return smalltalk.withContext(function($ctx2) { $1=_st(window)._alert_(_st(ex)._messageText());
  242. throw $early=[$1];
  243. }, function($ctx2) {$ctx2.fillBlock({ex:ex},$ctx1)})}));
  244. $2=_st(compiler)._evaluateExpression_on_(aString,aReceiver);
  245. return $2;
  246. }
  247. catch(e) {if(e===$early)return e[0]; throw e}
  248. }, function($ctx1) {$ctx1.fill(self,"eval:on:",{aString:aString,aReceiver:aReceiver,compiler:compiler}, smalltalk.HLLocalEnvironment)})},
  249. args: ["aString", "aReceiver"],
  250. source: "eval: aString on: aReceiver\x0a\x09| compiler |\x0a\x09compiler := Compiler new.\x0a\x09[ compiler parseExpression: aString ] on: Error do: [ :ex |\x0a\x09\x09^ window alert: ex messageText ].\x0a\x09^ compiler evaluateExpression: aString on: aReceiver",
  251. messageSends: ["new", "on:do:", "alert:", "messageText", "parseExpression:", "evaluateExpression:on:"],
  252. referencedClasses: ["Compiler", "Error"]
  253. }),
  254. smalltalk.HLLocalEnvironment);
  255. smalltalk.addMethod(
  256. "_moveMethod_toClass_",
  257. smalltalk.method({
  258. selector: "moveMethod:toClass:",
  259. category: 'actions',
  260. fn: function (aMethod,aClassName){
  261. var self=this;
  262. var destinationClass;
  263. return smalltalk.withContext(function($ctx1) { var $1,$2,$3;
  264. destinationClass=_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._at_(_st(aClassName)._asSymbol());
  265. $1=destinationClass;
  266. if(($receiver = $1) == nil || $receiver == undefined){
  267. _st(self)._error_("Invalid class name");
  268. } else {
  269. $1;
  270. };
  271. $2=_st(destinationClass).__eq_eq(_st(aMethod)._methodClass());
  272. if(smalltalk.assert($2)){
  273. $3=self;
  274. return $3;
  275. };
  276. _st(destinationClass)._adoptMethod_(aMethod);
  277. _st(_st(aMethod)._methodClass())._forsakeMethod_(aMethod);
  278. return self}, function($ctx1) {$ctx1.fill(self,"moveMethod:toClass:",{aMethod:aMethod,aClassName:aClassName,destinationClass:destinationClass},smalltalk.HLLocalEnvironment)})},
  279. args: ["aMethod", "aClassName"],
  280. source: "moveMethod: aMethod toClass: aClassName\x0a\x09| destinationClass |\x0a\x09\x0a\x09destinationClass := Smalltalk current at: aClassName asSymbol.\x0a\x09destinationClass ifNil: [ self error: 'Invalid class name' ].\x0a\x09destinationClass == aMethod methodClass ifTrue: [ ^ self ].\x0a\x09\x0a\x09destinationClass adoptMethod: aMethod.\x0a\x09aMethod methodClass forsakeMethod: aMethod.\x0a\x09",
  281. messageSends: ["at:", "asSymbol", "current", "ifNil:", "error:", "ifTrue:", "==", "methodClass", "adoptMethod:", "forsakeMethod:"],
  282. referencedClasses: ["Smalltalk"]
  283. }),
  284. smalltalk.HLLocalEnvironment);
  285. smalltalk.addMethod(
  286. "_packages",
  287. smalltalk.method({
  288. selector: "packages",
  289. category: 'accessing',
  290. fn: function (){
  291. var self=this;
  292. return smalltalk.withContext(function($ctx1) { var $1;
  293. $1=_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packages();
  294. return $1;
  295. }, function($ctx1) {$ctx1.fill(self,"packages",{}, smalltalk.HLLocalEnvironment)})},
  296. args: [],
  297. source: "packages\x0a\x09^ Smalltalk current packages",
  298. messageSends: ["packages", "current"],
  299. referencedClasses: ["Smalltalk"]
  300. }),
  301. smalltalk.HLLocalEnvironment);
  302. smalltalk.addClass('HLRemoteEnvironment', smalltalk.HLEnvironment, [], 'Helios-Environments');
  303. smalltalk.addMethod(
  304. "_eval_on_",
  305. smalltalk.method({
  306. selector: "eval:on:",
  307. category: 'actions',
  308. fn: function (someCode,aReceiver){
  309. var self=this;
  310. return smalltalk.withContext(function($ctx1) { _st(self)._notYetImplemented();
  311. return self}, function($ctx1) {$ctx1.fill(self,"eval:on:",{someCode:someCode,aReceiver:aReceiver}, smalltalk.HLRemoteEnvironment)})},
  312. args: ["someCode", "aReceiver"],
  313. source: "eval: someCode on: aReceiver\x0a\x0a\x09\x22Note for future self and friends:\x0a whatever way this compilation happens on the other side, \x0a it should return a proxy to the remote resulting object\x22\x0a \x0a self notYetImplemented",
  314. messageSends: ["notYetImplemented"],
  315. referencedClasses: []
  316. }),
  317. smalltalk.HLRemoteEnvironment);
  318. smalltalk.addMethod(
  319. "_packages",
  320. smalltalk.method({
  321. selector: "packages",
  322. category: 'accessing',
  323. fn: function (){
  324. var self=this;
  325. return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"packages",{}, smalltalk.HLRemoteEnvironment)})},
  326. args: [],
  327. source: "packages\x0a\x09\x22Answer the remote environment's packages\x22\x0a \x0a\x09\x22to-do\x22\x0a \x0a \x22Note for future self and friends:\x0a the problem with remote stuff is that the answers shouldn't be expected to be\x0a received in a syncrhonous fashion. Everything network is asyc, so you *are going to deal with callbacks* here\x22",
  328. messageSends: [],
  329. referencedClasses: []
  330. }),
  331. smalltalk.HLRemoteEnvironment);
  332. smalltalk.addClass('HLRemoteObject', smalltalk.Object, [], 'Helios-Environments');
  333. smalltalk.HLRemoteObject.comment="This is a local proxy to a remote object.\x0aTipically useful for evaluating and inspecting and interacting with instances of a remote VM.\x0a"
  334. smalltalk.addMethod(
  335. "_doesNotUnderstand_",
  336. smalltalk.method({
  337. selector: "doesNotUnderstand:",
  338. category: 'actions',
  339. fn: function (aMessage){
  340. var self=this;
  341. return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage}, smalltalk.HLRemoteObject)})},
  342. args: ["aMessage"],
  343. source: "doesNotUnderstand: aMessage\x0a\x0a\x09\x22to-do\x0a\x0a\x09aham, blah blah\x0a\x0a\x09super doesNotUnderstand: aMessage\x22",
  344. messageSends: [],
  345. referencedClasses: []
  346. }),
  347. smalltalk.HLRemoteObject);
  348. smalltalk.addMethod(
  349. "_inspectOn_",
  350. smalltalk.method({
  351. selector: "inspectOn:",
  352. category: 'actions',
  353. fn: function (anInspector){
  354. var self=this;
  355. return smalltalk.withContext(function($ctx1) { return self}, function($ctx1) {$ctx1.fill(self,"inspectOn:",{anInspector:anInspector}, smalltalk.HLRemoteObject)})},
  356. args: ["anInspector"],
  357. source: "inspectOn: anInspector\x0a\x0a\x09\x22to-do\x22\x0a\x0a\x09\x22this is a source of so much fun...\x22\x0a",
  358. messageSends: [],
  359. referencedClasses: []
  360. }),
  361. smalltalk.HLRemoteObject);
  362. smalltalk.addMethod(
  363. "_printString",
  364. smalltalk.method({
  365. selector: "printString",
  366. category: 'actions',
  367. fn: function (){
  368. var self=this;
  369. return smalltalk.withContext(function($ctx1) { return "this is a remote object";
  370. }, function($ctx1) {$ctx1.fill(self,"printString",{}, smalltalk.HLRemoteObject)})},
  371. args: [],
  372. source: "printString\x0a\x09^ 'this is a remote object'",
  373. messageSends: [],
  374. referencedClasses: []
  375. }),
  376. smalltalk.HLRemoteObject);
  377. smalltalk.addMethod(
  378. "_adoptMethod_",
  379. smalltalk.method({
  380. selector: "adoptMethod:",
  381. category: '*Helios-Environments',
  382. fn: function (aMethod){
  383. var self=this;
  384. return smalltalk.withContext(function($ctx1) { _st(self)._compile_category_(_st(aMethod)._source(),_st(aMethod)._protocol());
  385. return self}, function($ctx1) {$ctx1.fill(self,"adoptMethod:",{aMethod:aMethod},smalltalk.Behavior)})},
  386. args: ["aMethod"],
  387. source: "adoptMethod: aMethod\x0a\x09self \x0a\x09\x09compile: aMethod source\x0a\x09\x09category: aMethod protocol.",
  388. messageSends: ["compile:category:", "source", "protocol"],
  389. referencedClasses: []
  390. }),
  391. smalltalk.Behavior);
  392. smalltalk.addMethod(
  393. "_forsakeMethod_",
  394. smalltalk.method({
  395. selector: "forsakeMethod:",
  396. category: '*Helios-Environments',
  397. fn: function (aMethod){
  398. var self=this;
  399. return smalltalk.withContext(function($ctx1) { _st(self)._removeCompiledMethod_(aMethod);
  400. return self}, function($ctx1) {$ctx1.fill(self,"forsakeMethod:",{aMethod:aMethod},smalltalk.Behavior)})},
  401. args: ["aMethod"],
  402. source: "forsakeMethod: aMethod\x0a\x09self removeCompiledMethod: aMethod",
  403. messageSends: ["removeCompiledMethod:"],
  404. referencedClasses: []
  405. }),
  406. smalltalk.Behavior);