Importer-Exporter.js 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816
  1. smalltalk.addPackage('Importer-Exporter', {});
  2. smalltalk.addClass('ChunkParser', smalltalk.Object, ['stream'], 'Importer-Exporter');
  3. smalltalk.addMethod(
  4. "_nextChunk",
  5. smalltalk.method({
  6. selector: "nextChunk",
  7. category: 'reading',
  8. fn: function (){
  9. var self=this;
  10. return smalltalk.withContext(function($ctx) { var $1,$2,$3;
  11. var $early={};
  12. try {
  13. var char_;
  14. var result;
  15. var chunk;
  16. result=_st("")._writeStream();
  17. _st((function(){
  18. char_=_st(self["@stream"])._next();
  19. char_;
  20. return _st(char_)._notNil();
  21. }))._whileTrue_((function(){
  22. $1=_st(char_).__eq("!");
  23. if(smalltalk.assert($1)){
  24. $2=_st(_st(self["@stream"])._peek()).__eq("!");
  25. if(smalltalk.assert($2)){
  26. _st(self["@stream"])._next();
  27. } else {
  28. $3=_st(_st(result)._contents())._trimBoth();
  29. throw $early=[$3];
  30. };
  31. };
  32. return _st(result)._nextPut_(char_);
  33. }));
  34. return nil;
  35. }
  36. catch(e) {if(e===$early)return e[0]; throw e}
  37. }, self, "nextChunk", [], smalltalk.ChunkParser)},
  38. args: [],
  39. source: "nextChunk\x0a\x09\x22The chunk format (Smalltalk Interchange Format or Fileout format)\x0a\x09is a trivial format but can be a bit tricky to understand:\x0a\x09\x09- Uses the exclamation mark as delimiter of chunks.\x0a\x09\x09- Inside a chunk a normal exclamation mark must be doubled.\x0a\x09\x09- A non empty chunk must be a valid Smalltalk expression.\x0a\x09\x09- A chunk on top level with a preceding empty chunk is an instruction chunk:\x0a\x09\x09\x09- The object created by the expression then takes over reading chunks.\x0a\x0a\x09This metod returns next chunk as a String (trimmed), empty String (all whitespace) or nil.\x22\x0a\x0a\x09| char result chunk |\x0a\x09result := '' writeStream.\x0a [char := stream next.\x0a char notNil] whileTrue: [\x0a char = '!' ifTrue: [\x0a stream peek = '!'\x0a ifTrue: [stream next \x22skipping the escape double\x22]\x0a ifFalse: [^result contents trimBoth \x22chunk end marker found\x22]].\x0a result nextPut: char].\x0a\x09^nil \x22a chunk needs to end with !\x22",
  40. messageSends: ["writeStream", "whileTrue:", "ifTrue:", "ifTrue:ifFalse:", "next", "trimBoth", "contents", "=", "peek", "nextPut:", "notNil"],
  41. referencedClasses: []
  42. }),
  43. smalltalk.ChunkParser);
  44. smalltalk.addMethod(
  45. "_stream_",
  46. smalltalk.method({
  47. selector: "stream:",
  48. category: 'accessing',
  49. fn: function (aStream){
  50. var self=this;
  51. return smalltalk.withContext(function($ctx) { self["@stream"]=aStream;
  52. return self}, self, "stream:", [aStream], smalltalk.ChunkParser)},
  53. args: ["aStream"],
  54. source: "stream: aStream\x0a\x09stream := aStream",
  55. messageSends: [],
  56. referencedClasses: []
  57. }),
  58. smalltalk.ChunkParser);
  59. smalltalk.addMethod(
  60. "_on_",
  61. smalltalk.method({
  62. selector: "on:",
  63. category: 'not yet classified',
  64. fn: function (aStream){
  65. var self=this;
  66. return smalltalk.withContext(function($ctx) { var $1;
  67. $1=_st(_st(self)._new())._stream_(aStream);
  68. return $1;
  69. }, self, "on:", [aStream], smalltalk.ChunkParser.klass)},
  70. args: ["aStream"],
  71. source: "on: aStream\x0a\x09^self new stream: aStream",
  72. messageSends: ["stream:", "new"],
  73. referencedClasses: []
  74. }),
  75. smalltalk.ChunkParser.klass);
  76. smalltalk.addClass('Exporter', smalltalk.Object, [], 'Importer-Exporter');
  77. smalltalk.addMethod(
  78. "_classNameFor_",
  79. smalltalk.method({
  80. selector: "classNameFor:",
  81. category: 'private',
  82. fn: function (aClass){
  83. var self=this;
  84. return smalltalk.withContext(function($ctx) { var $2,$3,$1;
  85. $2=_st(aClass)._isMetaclass();
  86. if(smalltalk.assert($2)){
  87. $1=_st(_st(_st(aClass)._instanceClass())._name()).__comma(".klass");
  88. } else {
  89. $3=_st(aClass)._isNil();
  90. if(smalltalk.assert($3)){
  91. $1="nil";
  92. } else {
  93. $1=_st(aClass)._name();
  94. };
  95. };
  96. return $1;
  97. }, self, "classNameFor:", [aClass], smalltalk.Exporter)},
  98. args: ["aClass"],
  99. source: "classNameFor: aClass\x0a\x09^aClass isMetaclass\x0a\x09 ifTrue: [aClass instanceClass name, '.klass']\x0a\x09 ifFalse: [\x0a\x09\x09aClass isNil\x0a\x09\x09 ifTrue: ['nil']\x0a\x09\x09 ifFalse: [aClass name]]",
  100. messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
  101. referencedClasses: []
  102. }),
  103. smalltalk.Exporter);
  104. smalltalk.addMethod(
  105. "_exportAll",
  106. smalltalk.method({
  107. selector: "exportAll",
  108. category: 'fileOut',
  109. fn: function (){
  110. var self=this;
  111. return smalltalk.withContext(function($ctx) { var $1;
  112. $1=_st((smalltalk.String || String))._streamContents_((function(stream){
  113. return _st(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packages())._do_((function(pkg){
  114. return _st(stream)._nextPutAll_(_st(self)._exportPackage_(_st(pkg)._name()));
  115. }));
  116. }));
  117. return $1;
  118. }, self, "exportAll", [], smalltalk.Exporter)},
  119. args: [],
  120. source: "exportAll\x0a \x22Export all packages in the system.\x22\x0a\x0a ^String streamContents: [:stream |\x0a \x09Smalltalk current packages do: [:pkg |\x0a\x09\x09stream nextPutAll: (self exportPackage: pkg name)]]",
  121. messageSends: ["streamContents:", "do:", "nextPutAll:", "exportPackage:", "name", "packages", "current"],
  122. referencedClasses: ["Smalltalk", "String"]
  123. }),
  124. smalltalk.Exporter);
  125. smalltalk.addMethod(
  126. "_exportClass_",
  127. smalltalk.method({
  128. selector: "exportClass:",
  129. category: 'fileOut',
  130. fn: function (aClass){
  131. var self=this;
  132. return smalltalk.withContext(function($ctx) { var $1;
  133. $1=_st((smalltalk.String || String))._streamContents_((function(stream){
  134. _st(self)._exportDefinitionOf_on_(aClass,stream);
  135. _st(self)._exportMethodsOf_on_(aClass,stream);
  136. _st(self)._exportMetaDefinitionOf_on_(aClass,stream);
  137. return _st(self)._exportMethodsOf_on_(_st(aClass)._class(),stream);
  138. }));
  139. return $1;
  140. }, self, "exportClass:", [aClass], smalltalk.Exporter)},
  141. args: ["aClass"],
  142. source: "exportClass: aClass\x0a\x09\x22Export a single class. Subclasses override these methods.\x22\x0a\x0a\x09^String streamContents: [:stream |\x0a\x09\x09self exportDefinitionOf: aClass on: stream.\x0a\x09\x09self exportMethodsOf: aClass on: stream.\x0a\x09\x09self exportMetaDefinitionOf: aClass on: stream.\x0a\x09\x09self exportMethodsOf: aClass class on: stream]",
  143. messageSends: ["streamContents:", "exportDefinitionOf:on:", "exportMethodsOf:on:", "exportMetaDefinitionOf:on:", "class"],
  144. referencedClasses: ["String"]
  145. }),
  146. smalltalk.Exporter);
  147. smalltalk.addMethod(
  148. "_exportDefinitionOf_on_",
  149. smalltalk.method({
  150. selector: "exportDefinitionOf:on:",
  151. category: 'private',
  152. fn: function (aClass,aStream){
  153. var self=this;
  154. return smalltalk.withContext(function($ctx) { var $1,$2,$3,$4;
  155. _st(aStream)._nextPutAll_("smalltalk.addClass(");
  156. _st(aStream)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
  157. _st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
  158. $1=_st(aStream)._nextPutAll_(", [");
  159. _st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
  160. return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
  161. }),(function(){
  162. return _st(aStream)._nextPutAll_(", ");
  163. }));
  164. _st(aStream)._nextPutAll_("], '");
  165. _st(aStream)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
  166. $2=_st(aStream)._nextPutAll_(");");
  167. $3=_st(_st(aClass)._comment())._notEmpty();
  168. if(smalltalk.assert($3)){
  169. _st(aStream)._lf();
  170. _st(aStream)._nextPutAll_("smalltalk.");
  171. _st(aStream)._nextPutAll_(_st(self)._classNameFor_(aClass));
  172. _st(aStream)._nextPutAll_(".comment=");
  173. $4=_st(aStream)._nextPutAll_(_st(_st(aClass)._comment())._asJavascript());
  174. $4;
  175. };
  176. _st(aStream)._lf();
  177. return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)},
  178. args: ["aClass", "aStream"],
  179. source: "exportDefinitionOf: aClass on: aStream\x0a\x09aStream \x0a\x09 nextPutAll: 'smalltalk.addClass(';\x0a\x09 nextPutAll: '''', (self classNameFor: aClass), ''', ';\x0a\x09 nextPutAll: 'smalltalk.', (self classNameFor: aClass superclass);\x0a\x09 nextPutAll: ', ['.\x0a\x09aClass instanceVariableNames \x0a\x09 do: [:each | aStream nextPutAll: '''', each, '''']\x0a\x09 separatedBy: [aStream nextPutAll: ', '].\x0a\x09aStream\x09\x0a\x09 nextPutAll: '], ''';\x0a\x09 nextPutAll: aClass category, '''';\x0a\x09 nextPutAll: ');'.\x0a\x09aClass comment notEmpty ifTrue: [\x0a\x09 aStream \x0a\x09 \x09lf;\x0a\x09\x09nextPutAll: 'smalltalk.';\x0a\x09\x09nextPutAll: (self classNameFor: aClass);\x0a\x09\x09nextPutAll: '.comment=';\x0a\x09\x09nextPutAll: aClass comment asJavascript].\x0a\x09aStream lf",
  180. messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "lf", "asJavascript", "comment", "notEmpty"],
  181. referencedClasses: []
  182. }),
  183. smalltalk.Exporter);
  184. smalltalk.addMethod(
  185. "_exportMetaDefinitionOf_on_",
  186. smalltalk.method({
  187. selector: "exportMetaDefinitionOf:on:",
  188. category: 'private',
  189. fn: function (aClass,aStream){
  190. var self=this;
  191. return smalltalk.withContext(function($ctx) { var $1,$2;
  192. $1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
  193. if(! smalltalk.assert($1)){
  194. _st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._class())));
  195. $2=_st(aStream)._nextPutAll_(".iVarNames = [");
  196. $2;
  197. _st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
  198. return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
  199. }),(function(){
  200. return _st(aStream)._nextPutAll_(",");
  201. }));
  202. _st(aStream)._nextPutAll_(_st("];").__comma(_st((smalltalk.String || String))._lf()));
  203. };
  204. return self}, self, "exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)},
  205. args: ["aClass", "aStream"],
  206. source: "exportMetaDefinitionOf: aClass on: aStream\x0a\x09aClass class instanceVariableNames isEmpty ifFalse: [\x0a\x09 aStream \x0a\x09\x09nextPutAll: 'smalltalk.', (self classNameFor: aClass class);\x0a\x09\x09nextPutAll: '.iVarNames = ['.\x0a\x09 aClass class instanceVariableNames\x0a\x09\x09do: [:each | aStream nextPutAll: '''', each, '''']\x0a\x09\x09separatedBy: [aStream nextPutAll: ','].\x0a\x09 aStream nextPutAll: '];', String lf]",
  207. messageSends: ["ifFalse:", "nextPutAll:", ",", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
  208. referencedClasses: ["String"]
  209. }),
  210. smalltalk.Exporter);
  211. smalltalk.addMethod(
  212. "_exportMethod_of_on_",
  213. smalltalk.method({
  214. selector: "exportMethod:of:on:",
  215. category: 'private',
  216. fn: function (aMethod,aClass,aStream){
  217. var self=this;
  218. return smalltalk.withContext(function($ctx) { var $1,$2;
  219. _st(aStream)._nextPutAll_("smalltalk.addMethod(");
  220. _st(aStream)._lf();
  221. _st(aStream)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
  222. _st(aStream)._lf();
  223. _st(aStream)._nextPutAll_("smalltalk.method({");
  224. _st(aStream)._lf();
  225. _st(aStream)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
  226. _st(aStream)._lf();
  227. _st(aStream)._nextPutAll_(_st(_st("category: '").__comma(_st(aMethod)._category())).__comma("',"));
  228. _st(aStream)._lf();
  229. _st(aStream)._nextPutAll_(_st(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource())).__comma(","));
  230. _st(aStream)._lf();
  231. _st(aStream)._nextPutAll_(_st(_st("args: ").__comma(_st(_st(aMethod)._arguments())._asJavascript())).__comma(","));
  232. _st(aStream)._lf();
  233. _st(aStream)._nextPutAll_(_st(_st("source: ").__comma(_st(_st(aMethod)._source())._asJavascript())).__comma(","));
  234. _st(aStream)._lf();
  235. _st(aStream)._nextPutAll_(_st(_st("messageSends: ").__comma(_st(_st(aMethod)._messageSends())._asJavascript())).__comma(","));
  236. _st(aStream)._lf();
  237. $1=_st(aStream)._nextPutAll_(_st("referencedClasses: ").__comma(_st(_st(aMethod)._referencedClasses())._asJavascript()));
  238. _st(aStream)._lf();
  239. _st(aStream)._nextPutAll_("}),");
  240. _st(aStream)._lf();
  241. _st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
  242. _st(aStream)._nextPutAll_(");");
  243. _st(aStream)._lf();
  244. $2=_st(aStream)._lf();
  245. return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.Exporter)},
  246. args: ["aMethod", "aClass", "aStream"],
  247. source: "exportMethod: aMethod of: aClass on: aStream\x0a\x09aStream \x0a\x09\x09nextPutAll: 'smalltalk.addMethod(';lf;\x0a\x09\x09nextPutAll: aMethod selector asSelector asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'smalltalk.method({';lf;\x0a\x09\x09nextPutAll: 'selector: ', aMethod selector asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'category: ''', aMethod category, ''',';lf;\x0a\x09\x09nextPutAll: 'fn: ', aMethod fn compiledSource, ',';lf;\x0a\x09\x09nextPutAll: 'args: ', aMethod arguments asJavascript, ','; lf;\x0a\x09\x09nextPutAll: 'source: ', aMethod source asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'messageSends: ', aMethod messageSends asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'referencedClasses: ', aMethod referencedClasses asJavascript.\x0a\x09aStream\x0a\x09\x09lf;\x0a\x09\x09nextPutAll: '}),';lf;\x0a\x09\x09nextPutAll: 'smalltalk.', (self classNameFor: aClass);\x0a\x09\x09nextPutAll: ');';lf;lf",
  248. messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "category", "compiledSource", "fn", "arguments", "source", "messageSends", "referencedClasses", "classNameFor:"],
  249. referencedClasses: []
  250. }),
  251. smalltalk.Exporter);
  252. smalltalk.addMethod(
  253. "_exportMethodsOf_on_",
  254. smalltalk.method({
  255. selector: "exportMethodsOf:on:",
  256. category: 'private',
  257. fn: function (aClass,aStream){
  258. var self=this;
  259. return smalltalk.withContext(function($ctx) { var $1;
  260. _st(_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
  261. return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
  262. })))._do_((function(each){
  263. $1=_st(_st(each)._category())._match_("^\x5c*");
  264. if(! smalltalk.assert($1)){
  265. return _st(self)._exportMethod_of_on_(each,aClass,aStream);
  266. };
  267. }));
  268. _st(aStream)._lf();
  269. return self}, self, "exportMethodsOf:on:", [aClass,aStream], smalltalk.Exporter)},
  270. args: ["aClass", "aStream"],
  271. source: "exportMethodsOf: aClass on: aStream\x0a\x09\x22Issue #143: sort methods alphabetically\x22\x0a\x0a\x09((aClass methodDictionary values) sorted: [:a :b | a selector <= b selector]) do: [:each |\x0a\x09\x09(each category match: '^\x5c*') ifFalse: [\x0a\x09\x09\x09self exportMethod: each of: aClass on: aStream]].\x0a\x09aStream lf",
  272. messageSends: ["do:", "ifFalse:", "exportMethod:of:on:", "match:", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "lf"],
  273. referencedClasses: []
  274. }),
  275. smalltalk.Exporter);
  276. smalltalk.addMethod(
  277. "_exportPackage_",
  278. smalltalk.method({
  279. selector: "exportPackage:",
  280. category: 'fileOut',
  281. fn: function (packageName){
  282. var self=this;
  283. return smalltalk.withContext(function($ctx) { var $1;
  284. var package;
  285. $1=_st((smalltalk.String || String))._streamContents_((function(stream){
  286. package=_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packageAt_(packageName);
  287. package;
  288. _st(self)._exportPackageDefinitionOf_on_(package,stream);
  289. _st(_st(_st(package)._sortedClasses())._asSet())._do_((function(each){
  290. return _st(stream)._nextPutAll_(_st(self)._exportClass_(each));
  291. }));
  292. return _st(self)._exportPackageExtensionsOf_on_(package,stream);
  293. }));
  294. return $1;
  295. }, self, "exportPackage:", [packageName], smalltalk.Exporter)},
  296. args: ["packageName"],
  297. source: "exportPackage: packageName\x0a\x09\x22Export a given package by name.\x22\x0a\x0a\x09| package |\x0a\x09^String streamContents: [:stream |\x0a package := Smalltalk current packageAt: packageName.\x0a self exportPackageDefinitionOf: package on: stream.\x0a\x0a\x09\x09\x22Export classes in dependency order.\x0a\x09\x09Update (issue #171): Remove duplicates for export\x22\x0a\x09 \x09package sortedClasses asSet do: [:each |\x0a stream nextPutAll: (self exportClass: each)].\x0a\x09\x09self exportPackageExtensionsOf: package on: stream]",
  298. messageSends: ["streamContents:", "packageAt:", "current", "exportPackageDefinitionOf:on:", "do:", "nextPutAll:", "exportClass:", "asSet", "sortedClasses", "exportPackageExtensionsOf:on:"],
  299. referencedClasses: ["Smalltalk", "String"]
  300. }),
  301. smalltalk.Exporter);
  302. smalltalk.addMethod(
  303. "_exportPackageDefinitionOf_on_",
  304. smalltalk.method({
  305. selector: "exportPackageDefinitionOf:on:",
  306. category: 'private',
  307. fn: function (package,aStream){
  308. var self=this;
  309. return smalltalk.withContext(function($ctx) { var $1;
  310. _st(aStream)._nextPutAll_("smalltalk.addPackage(");
  311. $1=_st(aStream)._nextPutAll_(_st(_st(_st(_st("'").__comma(_st(package)._name())).__comma("', ")).__comma(_st(package)._propertiesAsJSON())).__comma(");"));
  312. _st(aStream)._lf();
  313. return self}, self, "exportPackageDefinitionOf:on:", [package,aStream], smalltalk.Exporter)},
  314. args: ["package", "aStream"],
  315. source: "exportPackageDefinitionOf: package on: aStream\x0a\x09aStream \x0a\x09 nextPutAll: 'smalltalk.addPackage(';\x0a\x09 nextPutAll: '''', package name, ''', ', package propertiesAsJSON , ');'.\x0a\x09aStream lf",
  316. messageSends: ["nextPutAll:", ",", "propertiesAsJSON", "name", "lf"],
  317. referencedClasses: []
  318. }),
  319. smalltalk.Exporter);
  320. smalltalk.addMethod(
  321. "_exportPackageExtensionsOf_on_",
  322. smalltalk.method({
  323. selector: "exportPackageExtensionsOf:on:",
  324. category: 'private',
  325. fn: function (package,aStream){
  326. var self=this;
  327. return smalltalk.withContext(function($ctx) { var $1;
  328. var name;
  329. name=_st(package)._name();
  330. _st(_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes()))._do_((function(each){
  331. return _st([each,_st(each)._class()])._do_((function(aClass){
  332. return _st(_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
  333. return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
  334. })))._do_((function(method){
  335. $1=_st(_st(method)._category())._match_(_st("^\x5c*").__comma(name));
  336. if(smalltalk.assert($1)){
  337. return _st(self)._exportMethod_of_on_(method,aClass,aStream);
  338. };
  339. }));
  340. }));
  341. }));
  342. return self}, self, "exportPackageExtensionsOf:on:", [package,aStream], smalltalk.Exporter)},
  343. args: ["package", "aStream"],
  344. source: "exportPackageExtensionsOf: package on: aStream\x0a\x09\x22Issue #143: sort classes and methods alphabetically\x22\x0a\x0a\x09| name |\x0a\x09name := package name.\x0a\x09(Package sortedClasses: Smalltalk current classes) do: [:each |\x0a\x09\x09{each. each class} do: [:aClass | \x0a\x09\x09\x09((aClass methodDictionary values) sorted: [:a :b | a selector <= b selector]) do: [:method |\x0a\x09\x09\x09\x09(method category match: '^\x5c*', name) ifTrue: [\x0a\x09\x09\x09\x09\x09self exportMethod: method of: aClass on: aStream ]]]]",
  345. messageSends: ["name", "do:", "ifTrue:", "exportMethod:of:on:", "match:", ",", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "class", "sortedClasses:", "classes", "current"],
  346. referencedClasses: ["Smalltalk", "Package"]
  347. }),
  348. smalltalk.Exporter);
  349. smalltalk.addClass('ChunkExporter', smalltalk.Exporter, [], 'Importer-Exporter');
  350. smalltalk.addMethod(
  351. "_chunkEscape_",
  352. smalltalk.method({
  353. selector: "chunkEscape:",
  354. category: 'not yet classified',
  355. fn: function (aString){
  356. var self=this;
  357. return smalltalk.withContext(function($ctx) { var $1;
  358. $1=_st(_st(aString)._replace_with_("!","!!"))._trimBoth();
  359. return $1;
  360. }, self, "chunkEscape:", [aString], smalltalk.ChunkExporter)},
  361. args: ["aString"],
  362. source: "chunkEscape: aString\x0a\x09\x22Replace all occurrences of ! with !! and trim at both ends.\x22\x0a\x0a\x09^(aString replace: '!' with: '!!') trimBoth",
  363. messageSends: ["trimBoth", "replace:with:"],
  364. referencedClasses: []
  365. }),
  366. smalltalk.ChunkExporter);
  367. smalltalk.addMethod(
  368. "_classNameFor_",
  369. smalltalk.method({
  370. selector: "classNameFor:",
  371. category: 'not yet classified',
  372. fn: function (aClass){
  373. var self=this;
  374. return smalltalk.withContext(function($ctx) { var $2,$3,$1;
  375. $2=_st(aClass)._isMetaclass();
  376. if(smalltalk.assert($2)){
  377. $1=_st(_st(_st(aClass)._instanceClass())._name()).__comma(" class");
  378. } else {
  379. $3=_st(aClass)._isNil();
  380. if(smalltalk.assert($3)){
  381. $1="nil";
  382. } else {
  383. $1=_st(aClass)._name();
  384. };
  385. };
  386. return $1;
  387. }, self, "classNameFor:", [aClass], smalltalk.ChunkExporter)},
  388. args: ["aClass"],
  389. source: "classNameFor: aClass\x0a\x09^aClass isMetaclass\x0a\x09 ifTrue: [aClass instanceClass name, ' class']\x0a\x09 ifFalse: [\x0a\x09\x09aClass isNil\x0a\x09\x09 ifTrue: ['nil']\x0a\x09\x09 ifFalse: [aClass name]]",
  390. messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
  391. referencedClasses: []
  392. }),
  393. smalltalk.ChunkExporter);
  394. smalltalk.addMethod(
  395. "_exportDefinitionOf_on_",
  396. smalltalk.method({
  397. selector: "exportDefinitionOf:on:",
  398. category: 'not yet classified',
  399. fn: function (aClass,aStream){
  400. var self=this;
  401. return smalltalk.withContext(function($ctx) { var $1,$2,$3,$4;
  402. _st(aStream)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._superclass()));
  403. _st(aStream)._nextPutAll_(_st(" subclass: #").__comma(_st(self)._classNameFor_(aClass)));
  404. _st(aStream)._lf();
  405. $1=_st(aStream)._nextPutAll_("\x09instanceVariableNames: '");
  406. _st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
  407. return _st(aStream)._nextPutAll_(each);
  408. }),(function(){
  409. return _st(aStream)._nextPutAll_(" ");
  410. }));
  411. _st(aStream)._nextPutAll_("'");
  412. _st(aStream)._lf();
  413. _st(aStream)._nextPutAll_(_st(_st("\x09package: '").__comma(_st(aClass)._category())).__comma("'!"));
  414. $2=_st(aStream)._lf();
  415. $3=_st(_st(aClass)._comment())._notEmpty();
  416. if(smalltalk.assert($3)){
  417. _st(aStream)._nextPutAll_(_st(_st("!").__comma(_st(self)._classNameFor_(aClass))).__comma(" commentStamp!"));
  418. _st(aStream)._lf();
  419. _st(aStream)._nextPutAll_(_st(_st(self)._chunkEscape_(_st(aClass)._comment())).__comma("!"));
  420. $4=_st(aStream)._lf();
  421. $4;
  422. };
  423. _st(aStream)._lf();
  424. return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
  425. args: ["aClass", "aStream"],
  426. source: "exportDefinitionOf: aClass on: aStream\x0a \x22Chunk format.\x22\x0a\x0a aStream \x0a nextPutAll: (self classNameFor: aClass superclass);\x0a nextPutAll: ' subclass: #', (self classNameFor: aClass); lf;\x0a nextPutAll: '\x09instanceVariableNames: '''.\x0a aClass instanceVariableNames \x0a do: [:each | aStream nextPutAll: each]\x0a separatedBy: [aStream nextPutAll: ' '].\x0a aStream \x0a nextPutAll: ''''; lf;\x0a nextPutAll: '\x09package: ''', aClass category, '''!'; lf.\x0a aClass comment notEmpty ifTrue: [\x0a aStream \x0a nextPutAll: '!', (self classNameFor: aClass), ' commentStamp!';lf;\x0a nextPutAll: (self chunkEscape: aClass comment), '!';lf].\x0a aStream lf",
  427. messageSends: ["nextPutAll:", "classNameFor:", "superclass", ",", "lf", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "chunkEscape:", "comment", "notEmpty"],
  428. referencedClasses: []
  429. }),
  430. smalltalk.ChunkExporter);
  431. smalltalk.addMethod(
  432. "_exportMetaDefinitionOf_on_",
  433. smalltalk.method({
  434. selector: "exportMetaDefinitionOf:on:",
  435. category: 'not yet classified',
  436. fn: function (aClass,aStream){
  437. var self=this;
  438. return smalltalk.withContext(function($ctx) { var $1,$2,$3;
  439. $1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
  440. if(! smalltalk.assert($1)){
  441. _st(aStream)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._class()));
  442. $2=_st(aStream)._nextPutAll_(" instanceVariableNames: '");
  443. $2;
  444. _st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
  445. return _st(aStream)._nextPutAll_(each);
  446. }),(function(){
  447. return _st(aStream)._nextPutAll_(" ");
  448. }));
  449. _st(aStream)._nextPutAll_("'!");
  450. _st(aStream)._lf();
  451. $3=_st(aStream)._lf();
  452. $3;
  453. };
  454. return self}, self, "exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
  455. args: ["aClass", "aStream"],
  456. source: "exportMetaDefinitionOf: aClass on: aStream\x0a\x0a\x09aClass class instanceVariableNames isEmpty ifFalse: [\x0a\x09\x09aStream \x0a\x09\x09 nextPutAll: (self classNameFor: aClass class);\x0a\x09\x09 nextPutAll: ' instanceVariableNames: '''.\x0a\x09\x09aClass class instanceVariableNames \x0a\x09\x09 do: [:each | aStream nextPutAll: each]\x0a\x09\x09 separatedBy: [aStream nextPutAll: ' '].\x0a\x09\x09aStream\x09\x0a\x09\x09 nextPutAll: '''!'; lf; lf]",
  457. messageSends: ["ifFalse:", "nextPutAll:", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
  458. referencedClasses: []
  459. }),
  460. smalltalk.ChunkExporter);
  461. smalltalk.addMethod(
  462. "_exportMethod_of_on_",
  463. smalltalk.method({
  464. selector: "exportMethod:of:on:",
  465. category: 'not yet classified',
  466. fn: function (aMethod,aClass,aStream){
  467. var self=this;
  468. return smalltalk.withContext(function($ctx) { var $1;
  469. _st(aStream)._lf();
  470. _st(aStream)._lf();
  471. _st(aStream)._nextPutAll_(_st(self)._chunkEscape_(_st(aMethod)._source()));
  472. _st(aStream)._lf();
  473. $1=_st(aStream)._nextPutAll_("!");
  474. return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.ChunkExporter)},
  475. args: ["aMethod", "aClass", "aStream"],
  476. source: "exportMethod: aMethod of: aClass on: aStream\x0a\x09aStream \x0a\x09\x09lf; lf; nextPutAll: (self chunkEscape: aMethod source); lf;\x0a\x09\x09nextPutAll: '!'",
  477. messageSends: ["lf", "nextPutAll:", "chunkEscape:", "source"],
  478. referencedClasses: []
  479. }),
  480. smalltalk.ChunkExporter);
  481. smalltalk.addMethod(
  482. "_exportMethods_category_of_on_",
  483. smalltalk.method({
  484. selector: "exportMethods:category:of:on:",
  485. category: 'not yet classified',
  486. fn: function (methods,category,aClass,aStream){
  487. var self=this;
  488. return smalltalk.withContext(function($ctx) { var $1,$2;
  489. _st(aStream)._nextPutAll_(_st("!").__comma(_st(self)._classNameFor_(aClass)));
  490. $1=_st(aStream)._nextPutAll_(_st(_st(" methodsFor: '").__comma(category)).__comma("'!"));
  491. _st(_st(methods)._sorted_((function(a,b){
  492. return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
  493. })))._do_((function(each){
  494. return _st(self)._exportMethod_of_on_(each,aClass,aStream);
  495. }));
  496. _st(aStream)._nextPutAll_(" !");
  497. _st(aStream)._lf();
  498. $2=_st(aStream)._lf();
  499. return self}, self, "exportMethods:category:of:on:", [methods,category,aClass,aStream], smalltalk.ChunkExporter)},
  500. args: ["methods", "category", "aClass", "aStream"],
  501. source: "exportMethods: methods category: category of: aClass on: aStream\x0a\x09\x22Issue #143: sort methods alphabetically\x22\x0a\x0a\x09aStream\x0a\x09\x09nextPutAll: '!', (self classNameFor: aClass);\x0a\x09\x09nextPutAll: ' methodsFor: ''', category, '''!'.\x0a\x09\x09(methods sorted: [:a :b | a selector <= b selector]) do: [:each |\x0a\x09\x09\x09\x09self exportMethod: each of: aClass on: aStream].\x0a\x09aStream nextPutAll: ' !'; lf; lf",
  502. messageSends: ["nextPutAll:", ",", "classNameFor:", "do:", "exportMethod:of:on:", "sorted:", "<=", "selector", "lf"],
  503. referencedClasses: []
  504. }),
  505. smalltalk.ChunkExporter);
  506. smalltalk.addMethod(
  507. "_exportMethodsOf_on_",
  508. smalltalk.method({
  509. selector: "exportMethodsOf:on:",
  510. category: 'not yet classified',
  511. fn: function (aClass,aStream){
  512. var self=this;
  513. return smalltalk.withContext(function($ctx) { var $1;
  514. var map;
  515. map=_st((smalltalk.Dictionary || Dictionary))._new();
  516. _st(aClass)._protocolsDo_((function(category,methods){
  517. $1=_st(category)._match_("^\x5c*");
  518. if(! smalltalk.assert($1)){
  519. return _st(map)._at_put_(category,methods);
  520. };
  521. }));
  522. _st(_st(_st(map)._keys())._sorted_((function(a,b){
  523. return _st(a).__lt_eq(b);
  524. })))._do_((function(category){
  525. var methods;
  526. methods=_st(map)._at_(category);
  527. methods;
  528. return _st(self)._exportMethods_category_of_on_(methods,category,aClass,aStream);
  529. }));
  530. return self}, self, "exportMethodsOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
  531. args: ["aClass", "aStream"],
  532. source: "exportMethodsOf: aClass on: aStream\x0a\x09\x22Issue #143: sort protocol alphabetically\x22\x0a\x0a\x09| map |\x0a\x09map := Dictionary new.\x0a\x09aClass protocolsDo: [:category :methods | \x0a\x09\x09(category match: '^\x5c*') ifFalse: [ map at: category put: methods ]].\x0a\x09(map keys sorted: [:a :b | a <= b ]) do: [:category | | methods |\x0a\x09\x09methods := map at: category.\x0a\x09\x09self\x0a\x09\x09\x09exportMethods: methods\x0a\x09\x09\x09category: category\x0a\x09\x09\x09of: aClass\x0a\x09\x09\x09on: aStream ]",
  533. messageSends: ["new", "protocolsDo:", "ifFalse:", "at:put:", "match:", "do:", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys"],
  534. referencedClasses: ["Dictionary"]
  535. }),
  536. smalltalk.ChunkExporter);
  537. smalltalk.addMethod(
  538. "_exportPackageDefinitionOf_on_",
  539. smalltalk.method({
  540. selector: "exportPackageDefinitionOf:on:",
  541. category: 'not yet classified',
  542. fn: function (package,aStream){
  543. var self=this;
  544. return smalltalk.withContext(function($ctx) { var $1;
  545. _st(aStream)._nextPutAll_(_st(_st(_st(_st("Smalltalk current createPackage: '").__comma(_st(package)._name())).__comma("' properties: ")).__comma(_st(_st(package)._properties())._storeString())).__comma("!"));
  546. $1=_st(aStream)._lf();
  547. return self}, self, "exportPackageDefinitionOf:on:", [package,aStream], smalltalk.ChunkExporter)},
  548. args: ["package", "aStream"],
  549. source: "exportPackageDefinitionOf: package on: aStream\x0a\x09\x22Chunk format.\x22\x0a\x0a\x09aStream \x0a\x09 nextPutAll: 'Smalltalk current createPackage: ''', package name,\x0a\x09\x09''' properties: ', package properties storeString, '!'; lf.",
  550. messageSends: ["nextPutAll:", ",", "storeString", "properties", "name", "lf"],
  551. referencedClasses: []
  552. }),
  553. smalltalk.ChunkExporter);
  554. smalltalk.addMethod(
  555. "_exportPackageExtensionsOf_on_",
  556. smalltalk.method({
  557. selector: "exportPackageExtensionsOf:on:",
  558. category: 'not yet classified',
  559. fn: function (package,aStream){
  560. var self=this;
  561. return smalltalk.withContext(function($ctx) { var $1;
  562. var name;
  563. var map;
  564. name=_st(package)._name();
  565. _st(_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes()))._do_((function(each){
  566. return _st([each,_st(each)._class()])._do_((function(aClass){
  567. map=_st((smalltalk.Dictionary || Dictionary))._new();
  568. map;
  569. _st(aClass)._protocolsDo_((function(category,methods){
  570. $1=_st(category)._match_(_st("^\x5c*").__comma(name));
  571. if(smalltalk.assert($1)){
  572. return _st(map)._at_put_(category,methods);
  573. };
  574. }));
  575. return _st(_st(_st(map)._keys())._sorted_((function(a,b){
  576. return _st(a).__lt_eq(b);
  577. })))._do_((function(category){
  578. var methods;
  579. methods=_st(map)._at_(category);
  580. methods;
  581. return _st(self)._exportMethods_category_of_on_(methods,category,aClass,aStream);
  582. }));
  583. }));
  584. }));
  585. return self}, self, "exportPackageExtensionsOf:on:", [package,aStream], smalltalk.ChunkExporter)},
  586. args: ["package", "aStream"],
  587. source: "exportPackageExtensionsOf: package on: aStream\x0a\x09\x22We need to override this one too since we need to group\x0a\x09all methods in a given protocol under a leading methodsFor: chunk\x0a\x09for that class.\x22\x0a\x0a\x09\x22Issue #143: sort protocol alphabetically\x22\x0a\x0a\x09| name map |\x0a\x09name := package name.\x0a\x09(Package sortedClasses: Smalltalk current classes) do: [:each |\x0a\x09\x09{each. each class} do: [:aClass |\x0a\x09\x09\x09map := Dictionary new.\x0a\x09\x09\x09aClass protocolsDo: [:category :methods | \x0a\x09\x09\x09\x09(category match: '^\x5c*', name) ifTrue: [ map at: category put: methods ]].\x0a\x09\x09\x09(map keys sorted: [:a :b | a <= b ]) do: [:category | | methods |\x0a\x09\x09\x09\x09methods := map at: category.\x09\x0a\x09\x09\x09\x09self exportMethods: methods category: category of: aClass on: aStream ]]]",
  588. messageSends: ["name", "do:", "new", "protocolsDo:", "ifTrue:", "at:put:", "match:", ",", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys", "class", "sortedClasses:", "classes", "current"],
  589. referencedClasses: ["Dictionary", "Smalltalk", "Package"]
  590. }),
  591. smalltalk.ChunkExporter);
  592. smalltalk.addClass('StrippedExporter', smalltalk.Exporter, [], 'Importer-Exporter');
  593. smalltalk.addMethod(
  594. "_exportDefinitionOf_on_",
  595. smalltalk.method({
  596. selector: "exportDefinitionOf:on:",
  597. category: 'private',
  598. fn: function (aClass,aStream){
  599. var self=this;
  600. return smalltalk.withContext(function($ctx) { var $1,$2;
  601. _st(aStream)._nextPutAll_("smalltalk.addClass(");
  602. _st(aStream)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
  603. _st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
  604. $1=_st(aStream)._nextPutAll_(", [");
  605. _st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
  606. return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
  607. }),(function(){
  608. return _st(aStream)._nextPutAll_(", ");
  609. }));
  610. _st(aStream)._nextPutAll_("], '");
  611. _st(aStream)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
  612. $2=_st(aStream)._nextPutAll_(");");
  613. _st(aStream)._lf();
  614. return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.StrippedExporter)},
  615. args: ["aClass", "aStream"],
  616. source: "exportDefinitionOf: aClass on: aStream\x0a\x09aStream \x0a\x09 nextPutAll: 'smalltalk.addClass(';\x0a\x09 nextPutAll: '''', (self classNameFor: aClass), ''', ';\x0a\x09 nextPutAll: 'smalltalk.', (self classNameFor: aClass superclass);\x0a\x09 nextPutAll: ', ['.\x0a\x09aClass instanceVariableNames \x0a\x09 do: [:each | aStream nextPutAll: '''', each, '''']\x0a\x09 separatedBy: [aStream nextPutAll: ', '].\x0a\x09aStream\x09\x0a\x09 nextPutAll: '], ''';\x0a\x09 nextPutAll: aClass category, '''';\x0a\x09 nextPutAll: ');'.\x0a\x09aStream lf",
  617. messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "lf"],
  618. referencedClasses: []
  619. }),
  620. smalltalk.StrippedExporter);
  621. smalltalk.addMethod(
  622. "_exportMethod_of_on_",
  623. smalltalk.method({
  624. selector: "exportMethod:of:on:",
  625. category: 'private',
  626. fn: function (aMethod,aClass,aStream){
  627. var self=this;
  628. return smalltalk.withContext(function($ctx) { var $1;
  629. _st(aStream)._nextPutAll_("smalltalk.addMethod(");
  630. _st(aStream)._lf();
  631. _st(aStream)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
  632. _st(aStream)._lf();
  633. _st(aStream)._nextPutAll_("smalltalk.method({");
  634. _st(aStream)._lf();
  635. _st(aStream)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
  636. _st(aStream)._lf();
  637. _st(aStream)._nextPutAll_(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource()));
  638. _st(aStream)._lf();
  639. _st(aStream)._nextPutAll_("}),");
  640. _st(aStream)._lf();
  641. _st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
  642. _st(aStream)._nextPutAll_(");");
  643. _st(aStream)._lf();
  644. $1=_st(aStream)._lf();
  645. return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.StrippedExporter)},
  646. args: ["aMethod", "aClass", "aStream"],
  647. source: "exportMethod: aMethod of: aClass on: aStream\x0a\x09aStream \x0a\x09\x09nextPutAll: 'smalltalk.addMethod(';lf;\x0a\x09\x09nextPutAll: aMethod selector asSelector asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'smalltalk.method({';lf;\x0a\x09\x09nextPutAll: 'selector: ', aMethod selector asJavascript, ',';lf;\x0a\x09\x09nextPutAll: 'fn: ', aMethod fn compiledSource;lf;\x0a\x09\x09nextPutAll: '}),';lf;\x0a\x09\x09nextPutAll: 'smalltalk.', (self classNameFor: aClass);\x0a\x09\x09nextPutAll: ');';lf;lf",
  648. messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "compiledSource", "fn", "classNameFor:"],
  649. referencedClasses: []
  650. }),
  651. smalltalk.StrippedExporter);
  652. smalltalk.addClass('Importer', smalltalk.Object, [], 'Importer-Exporter');
  653. smalltalk.addMethod(
  654. "_import_",
  655. smalltalk.method({
  656. selector: "import:",
  657. category: 'fileIn',
  658. fn: function (aStream){
  659. var self=this;
  660. return smalltalk.withContext(function($ctx) { var $1;
  661. var chunk;
  662. var result;
  663. var parser;
  664. var lastEmpty;
  665. parser=_st((smalltalk.ChunkParser || ChunkParser))._on_(aStream);
  666. lastEmpty=false;
  667. _st((function(){
  668. chunk=_st(parser)._nextChunk();
  669. chunk;
  670. return _st(chunk)._isNil();
  671. }))._whileFalse_((function(){
  672. $1=_st(chunk)._isEmpty();
  673. if(smalltalk.assert($1)){
  674. lastEmpty=true;
  675. return lastEmpty;
  676. } else {
  677. result=_st(_st((smalltalk.Compiler || Compiler))._new())._evaluateExpression_(chunk);
  678. result;
  679. if(smalltalk.assert(lastEmpty)){
  680. lastEmpty=false;
  681. lastEmpty;
  682. return _st(result)._scanFrom_(parser);
  683. };
  684. };
  685. }));
  686. return self}, self, "import:", [aStream], smalltalk.Importer)},
  687. args: ["aStream"],
  688. source: "import: aStream\x0a | chunk result parser lastEmpty |\x0a parser := ChunkParser on: aStream.\x0a lastEmpty := false.\x0a [chunk := parser nextChunk.\x0a chunk isNil] whileFalse: [\x0a chunk isEmpty\x0a \x09\x09ifTrue: [lastEmpty := true]\x0a \x09\x09ifFalse: [\x0a \x09\x09result := Compiler new evaluateExpression: chunk.\x0a \x09\x09lastEmpty \x0a \x09\x09\x09ifTrue: [\x0a \x09lastEmpty := false.\x0a \x09result scanFrom: parser]]]",
  689. messageSends: ["on:", "whileFalse:", "ifTrue:ifFalse:", "evaluateExpression:", "new", "ifTrue:", "scanFrom:", "isEmpty", "nextChunk", "isNil"],
  690. referencedClasses: ["ChunkParser", "Compiler"]
  691. }),
  692. smalltalk.Importer);
  693. smalltalk.addClass('PackageLoader', smalltalk.Object, [], 'Importer-Exporter');
  694. smalltalk.addMethod(
  695. "_initializePackageNamed_prefix_",
  696. smalltalk.method({
  697. selector: "initializePackageNamed:prefix:",
  698. category: 'not yet classified',
  699. fn: function (packageName,aString){
  700. var self=this;
  701. return smalltalk.withContext(function($ctx) { var $1,$2;
  702. _st(_st(_st((smalltalk.Package || Package))._named_(packageName))._classes())._do_((function(each){
  703. smalltalk.init(each);
  704. ;
  705. return _st(each)._initialize();
  706. }));
  707. $1=_st((smalltalk.Package || Package))._named_(packageName);
  708. _st($1)._commitPathJs_(_st(_st("/").__comma(aString)).__comma("/js"));
  709. $2=_st($1)._commitPathSt_(_st(_st("/").__comma(aString)).__comma("/st"));
  710. return self}, self, "initializePackageNamed:prefix:", [packageName,aString], smalltalk.PackageLoader)},
  711. args: ["packageName", "aString"],
  712. source: "initializePackageNamed: packageName prefix: aString\x0a\x0a\x09(Package named: packageName) classes do: [ :each |\x0a \x09<smalltalk.init(each)>.\x0a each initialize. ].\x0a \x0a (Package named: packageName) \x0a \x09commitPathJs: '/', aString, '/js';\x0a commitPathSt: '/', aString, '/st'",
  713. messageSends: ["do:", "initialize", "classes", "named:", "commitPathJs:", ",", "commitPathSt:"],
  714. referencedClasses: ["Package"]
  715. }),
  716. smalltalk.PackageLoader);
  717. smalltalk.addMethod(
  718. "_loadPackage_prefix_",
  719. smalltalk.method({
  720. selector: "loadPackage:prefix:",
  721. category: 'not yet classified',
  722. fn: function (packageName,aString){
  723. var self=this;
  724. return smalltalk.withContext(function($ctx) { var $1;
  725. var url;
  726. url=_st(_st(_st(_st("/").__comma(aString)).__comma("/js/")).__comma(packageName)).__comma(".js");
  727. _st(jQuery)._ajax_options_(url,smalltalk.HashedCollection._fromPairs_([_st("type").__minus_gt("GET"),_st("dataType").__minus_gt("script"),_st("complete").__minus_gt((function(jqXHR,textStatus){
  728. $1=_st(_st(jqXHR)._readyState()).__eq((4));
  729. if(smalltalk.assert($1)){
  730. return _st(self)._initializePackageNamed_prefix_(packageName,aString);
  731. };
  732. })),_st("error").__minus_gt((function(){
  733. return _st(window)._alert_(_st("Could not load package at: ").__comma(url));
  734. }))]));
  735. return self}, self, "loadPackage:prefix:", [packageName,aString], smalltalk.PackageLoader)},
  736. args: ["packageName", "aString"],
  737. source: "loadPackage: packageName prefix: aString\x09\x0a\x09| url |\x0a url := '/', aString, '/js/', packageName, '.js'.\x0a\x09jQuery \x0a\x09\x09ajax: url\x0a options: #{\x0a\x09\x09\x09'type' -> 'GET'.\x0a\x09\x09\x09'dataType' -> 'script'.\x0a \x09\x09'complete' -> [ :jqXHR :textStatus | \x0a\x09\x09\x09\x09jqXHR readyState = 4 \x0a \x09ifTrue: [ self initializePackageNamed: packageName prefix: aString ] ].\x0a\x09\x09\x09'error' -> [ window alert: 'Could not load package at: ', url ]\x0a\x09\x09}",
  738. messageSends: [",", "ajax:options:", "->", "ifTrue:", "initializePackageNamed:prefix:", "=", "readyState", "alert:"],
  739. referencedClasses: []
  740. }),
  741. smalltalk.PackageLoader);
  742. smalltalk.addMethod(
  743. "_loadPackages_prefix_",
  744. smalltalk.method({
  745. selector: "loadPackages:prefix:",
  746. category: 'not yet classified',
  747. fn: function (aCollection,aString){
  748. var self=this;
  749. return smalltalk.withContext(function($ctx) { _st(aCollection)._do_((function(each){
  750. return _st(self)._loadPackage_prefix_(each,aString);
  751. }));
  752. return self}, self, "loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader)},
  753. args: ["aCollection", "aString"],
  754. source: "loadPackages: aCollection prefix: aString\x0a\x09aCollection do: [ :each |\x0a \x09self loadPackage: each prefix: aString ]",
  755. messageSends: ["do:", "loadPackage:prefix:"],
  756. referencedClasses: []
  757. }),
  758. smalltalk.PackageLoader);
  759. smalltalk.addMethod(
  760. "_loadPackages_prefix_",
  761. smalltalk.method({
  762. selector: "loadPackages:prefix:",
  763. category: 'not yet classified',
  764. fn: function (aCollection,aString){
  765. var self=this;
  766. return smalltalk.withContext(function($ctx) { var $1;
  767. $1=_st(_st(self)._new())._loadPackages_prefix_(aCollection,aString);
  768. return $1;
  769. }, self, "loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader.klass)},
  770. args: ["aCollection", "aString"],
  771. source: "loadPackages: aCollection prefix: aString\x0a\x09^ self new loadPackages: aCollection prefix: aString",
  772. messageSends: ["loadPackages:prefix:", "new"],
  773. referencedClasses: []
  774. }),
  775. smalltalk.PackageLoader.klass);