|
@@ -7,34 +7,35 @@ selector: "nextChunk",
|
|
category: 'reading',
|
|
category: 'reading',
|
|
fn: function (){
|
|
fn: function (){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2,$3;
|
|
|
|
|
|
+var char,result,chunk;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$5,$6,$4,$2;
|
|
var $early={};
|
|
var $early={};
|
|
try {
|
|
try {
|
|
-$ctx1.char=nil;
|
|
|
|
-$ctx1.result=nil;
|
|
|
|
-$ctx1.chunk=nil;
|
|
|
|
-$ctx1.locals.result=_st("")._writeStream();
|
|
|
|
-_st((function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$ctx1.locals.char=_st(self["@stream"])._next();
|
|
|
|
-$ctx1.locals.char;
|
|
|
|
-return _st($ctx1.locals.char)._notNil();
|
|
|
|
-})}))._whileTrue_((function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$1=_st($ctx1.locals.char).__eq("!");
|
|
|
|
-if(smalltalk.assert($1)){
|
|
|
|
-$2=_st(_st(self["@stream"])._peek()).__eq("!");
|
|
|
|
-if(smalltalk.assert($2)){
|
|
|
|
-_st(self["@stream"])._next();
|
|
|
|
|
|
+result=_st("")._writeStream();
|
|
|
|
+$1=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
char=_st(self["@stream"])._next();
|
|
|
|
+char;
|
|
|
|
+return _st(char)._notNil();
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$2=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=_st(char).__eq("!");
|
|
|
|
+$4=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
$5=_st(_st(self["@stream"])._peek()).__eq("!");
|
|
|
|
+if(smalltalk.assert($5)){
|
|
|
|
+return _st(self["@stream"])._next();
|
|
} else {
|
|
} else {
|
|
-$3=_st(_st($ctx1.locals.result)._contents())._trimBoth();
|
|
|
|
-throw $early=[$3];
|
|
|
|
-};
|
|
|
|
|
|
+$6=_st(_st(result)._contents())._trimBoth();
|
|
|
|
+throw $early=[$6];
|
|
};
|
|
};
|
|
-return _st($ctx1.locals.result)._nextPut_($ctx1.locals.char);
|
|
|
|
-})}));
|
|
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})});
|
|
|
|
+_st($3)._ifTrue_($4);
|
|
|
|
+return _st(result)._nextPut_(char);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._whileTrue_($2);
|
|
return nil;
|
|
return nil;
|
|
}
|
|
}
|
|
catch(e) {if(e===$early)return e[0]; throw e}
|
|
catch(e) {if(e===$early)return e[0]; throw e}
|
|
-}, self, "nextChunk", [], smalltalk.ChunkParser)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"nextChunk", [], smalltalk.ChunkParser)})},
|
|
args: [],
|
|
args: [],
|
|
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",
|
|
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",
|
|
messageSends: ["writeStream", "whileTrue:", "ifTrue:", "ifTrue:ifFalse:", "next", "trimBoth", "contents", "=", "peek", "nextPut:", "notNil"],
|
|
messageSends: ["writeStream", "whileTrue:", "ifTrue:", "ifTrue:ifFalse:", "next", "trimBoth", "contents", "=", "peek", "nextPut:", "notNil"],
|
|
@@ -50,7 +51,7 @@ category: 'accessing',
|
|
fn: function (aStream){
|
|
fn: function (aStream){
|
|
var self=this;
|
|
var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
self["@stream"]=aStream;
|
|
return smalltalk.withContext(function($ctx1) {
self["@stream"]=aStream;
|
|
-return self}, self, "stream:", [aStream], smalltalk.ChunkParser)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"stream:", [aStream], smalltalk.ChunkParser)})},
|
|
args: ["aStream"],
|
|
args: ["aStream"],
|
|
source: "stream: aStream\x0a\x09stream := aStream",
|
|
source: "stream: aStream\x0a\x09stream := aStream",
|
|
messageSends: [],
|
|
messageSends: [],
|
|
@@ -69,7 +70,7 @@ var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
$1=_st(_st(self)._new())._stream_(aStream);
|
|
$1=_st(_st(self)._new())._stream_(aStream);
|
|
return $1;
|
|
return $1;
|
|
-}, self, "on:", [aStream], smalltalk.ChunkParser.klass)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"on:", [aStream], smalltalk.ChunkParser.klass)})},
|
|
args: ["aStream"],
|
|
args: ["aStream"],
|
|
source: "on: aStream\x0a\x09^self new stream: aStream",
|
|
source: "on: aStream\x0a\x09^self new stream: aStream",
|
|
messageSends: ["stream:", "new"],
|
|
messageSends: ["stream:", "new"],
|
|
@@ -86,20 +87,22 @@ selector: "classNameFor:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aClass){
|
|
fn: function (aClass){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $2,$3,$1;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $2,$3,$5,$4,$1;
|
|
$2=_st(aClass)._isMetaclass();
|
|
$2=_st(aClass)._isMetaclass();
|
|
-if(smalltalk.assert($2)){
|
|
|
|
-$1=_st(_st(_st(aClass)._instanceClass())._name()).__comma(".klass");
|
|
|
|
-} else {
|
|
|
|
-$3=_st(aClass)._isNil();
|
|
|
|
-if(smalltalk.assert($3)){
|
|
|
|
-$1="nil";
|
|
|
|
|
|
+$3=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(_st(_st(aClass)._instanceClass())._name()).__comma(".klass");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$4=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$5=_st(aClass)._isNil();
|
|
|
|
+if(smalltalk.assert($5)){
|
|
|
|
+return "nil";
|
|
} else {
|
|
} else {
|
|
-$1=_st(aClass)._name();
|
|
|
|
-};
|
|
|
|
|
|
+return _st(aClass)._name();
|
|
};
|
|
};
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$1=_st($2)._ifTrue_ifFalse_($3,$4);
|
|
return $1;
|
|
return $1;
|
|
-}, self, "classNameFor:", [aClass], smalltalk.Exporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"classNameFor:", [aClass], smalltalk.Exporter)})},
|
|
args: ["aClass"],
|
|
args: ["aClass"],
|
|
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]]",
|
|
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]]",
|
|
messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
|
|
messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
|
|
@@ -116,12 +119,12 @@ fn: function (){
|
|
var self=this;
|
|
var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packages())._do_((function(pkg){
|
|
|
|
-return smalltalk.withContext(function($ctx3) {
return _st(stream)._nextPutAll_(_st(self)._exportPackage_(_st(pkg)._name()));
|
|
|
|
-})}));
|
|
|
|
-})}));
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packages())._do_((function(pkg){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
return _st(stream)._nextPutAll_(_st(self)._exportPackage_(_st(pkg)._name()));
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})}));
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
return $1;
|
|
return $1;
|
|
-}, self, "exportAll", [], smalltalk.Exporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"exportAll", [], smalltalk.Exporter)})},
|
|
args: [],
|
|
args: [],
|
|
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)]]",
|
|
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)]]",
|
|
messageSends: ["streamContents:", "do:", "nextPutAll:", "exportPackage:", "name", "packages", "current"],
|
|
messageSends: ["streamContents:", "do:", "nextPutAll:", "exportPackage:", "name", "packages", "current"],
|
|
@@ -138,13 +141,13 @@ fn: function (aClass){
|
|
var self=this;
|
|
var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
-return smalltalk.withContext(function($ctx2) {
_st(self)._exportDefinitionOf_on_(aClass,stream);
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
_st(self)._exportDefinitionOf_on_(aClass,stream);
|
|
_st(self)._exportMethodsOf_on_(aClass,stream);
|
|
_st(self)._exportMethodsOf_on_(aClass,stream);
|
|
_st(self)._exportMetaDefinitionOf_on_(aClass,stream);
|
|
_st(self)._exportMetaDefinitionOf_on_(aClass,stream);
|
|
return _st(self)._exportMethodsOf_on_(_st(aClass)._class(),stream);
|
|
return _st(self)._exportMethodsOf_on_(_st(aClass)._class(),stream);
|
|
-})}));
|
|
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
return $1;
|
|
return $1;
|
|
-}, self, "exportClass:", [aClass], smalltalk.Exporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"exportClass:", [aClass], smalltalk.Exporter)})},
|
|
args: ["aClass"],
|
|
args: ["aClass"],
|
|
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]",
|
|
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]",
|
|
messageSends: ["streamContents:", "exportDefinitionOf:on:", "exportMethodsOf:on:", "exportMetaDefinitionOf:on:", "class"],
|
|
messageSends: ["streamContents:", "exportDefinitionOf:on:", "exportMethodsOf:on:", "exportMetaDefinitionOf:on:", "class"],
|
|
@@ -159,30 +162,33 @@ selector: "exportDefinitionOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4;
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.addClass(");
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
|
|
|
|
-_st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
|
|
|
|
-$1=_st(aStream)._nextPutAll_(", [");
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4,$5,$6,$7;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.addClass(");
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
|
|
|
|
+_st($1)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
|
|
|
|
+$2=_st($1)._nextPutAll_(", [");
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
-})}),(function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(", ");
|
|
|
|
-})}));
|
|
|
|
-_st(aStream)._nextPutAll_("], '");
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
|
|
|
|
-$2=_st(aStream)._nextPutAll_(");");
|
|
|
|
-$3=_st(_st(aClass)._comment())._notEmpty();
|
|
|
|
-if(smalltalk.assert($3)){
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.");
|
|
|
|
-_st(aStream)._nextPutAll_(_st(self)._classNameFor_(aClass));
|
|
|
|
-_st(aStream)._nextPutAll_(".comment=");
|
|
|
|
-$4=_st(aStream)._nextPutAll_(_st(_st(aClass)._comment())._asJavascript());
|
|
|
|
-$4;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}),(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(", ");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$3=aStream;
|
|
|
|
+_st($3)._nextPutAll_("], '");
|
|
|
|
+_st($3)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
|
|
|
|
+$4=_st($3)._nextPutAll_(");");
|
|
|
|
+$5=_st(_st(aClass)._comment())._notEmpty();
|
|
|
|
+if(smalltalk.assert($5)){
|
|
|
|
+$6=aStream;
|
|
|
|
+_st($6)._lf();
|
|
|
|
+_st($6)._nextPutAll_("smalltalk.");
|
|
|
|
+_st($6)._nextPutAll_(_st(self)._classNameFor_(aClass));
|
|
|
|
+_st($6)._nextPutAll_(".comment=");
|
|
|
|
+$7=_st($6)._nextPutAll_(_st(_st(aClass)._comment())._asJavascript());
|
|
|
|
+$7;
|
|
};
|
|
};
|
|
_st(aStream)._lf();
|
|
_st(aStream)._lf();
|
|
-return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "lf", "asJavascript", "comment", "notEmpty"],
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "lf", "asJavascript", "comment", "notEmpty"],
|
|
@@ -197,20 +203,21 @@ selector: "exportMetaDefinitionOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3;
|
|
$1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
|
|
$1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
|
|
if(! smalltalk.assert($1)){
|
|
if(! smalltalk.assert($1)){
|
|
-_st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._class())));
|
|
|
|
-$2=_st(aStream)._nextPutAll_(".iVarNames = [");
|
|
|
|
-$2;
|
|
|
|
|
|
+$2=aStream;
|
|
|
|
+_st($2)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._class())));
|
|
|
|
+$3=_st($2)._nextPutAll_(".iVarNames = [");
|
|
|
|
+$3;
|
|
_st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
|
|
_st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
-})}),(function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(",");
|
|
|
|
-})}));
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}),(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(",");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
_st(aStream)._nextPutAll_(_st("];").__comma(_st((smalltalk.String || String))._lf()));
|
|
_st(aStream)._nextPutAll_(_st("];").__comma(_st((smalltalk.String || String))._lf()));
|
|
};
|
|
};
|
|
-return self}, self, "exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.Exporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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]",
|
|
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]",
|
|
messageSends: ["ifFalse:", "nextPutAll:", ",", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
|
|
messageSends: ["ifFalse:", "nextPutAll:", ",", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
|
|
@@ -225,34 +232,36 @@ selector: "exportMethod:of:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aMethod,aClass,aStream){
|
|
fn: function (aMethod,aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.addMethod(");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.method({");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("category: '").__comma(_st(aMethod)._category())).__comma("',"));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("args: ").__comma(_st(_st(aMethod)._arguments())._asJavascript())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("source: ").__comma(_st(_st(aMethod)._source())._asJavascript())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("messageSends: ").__comma(_st(_st(aMethod)._messageSends())._asJavascript())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$1=_st(aStream)._nextPutAll_(_st("referencedClasses: ").__comma(_st(_st(aMethod)._referencedClasses())._asJavascript()));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_("}),");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
-_st(aStream)._nextPutAll_(");");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$2=_st(aStream)._lf();
|
|
|
|
-return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.addMethod(");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.method({");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("category: '").__comma(_st(aMethod)._category())).__comma("',"));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("args: ").__comma(_st(_st(aMethod)._arguments())._asJavascript())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("source: ").__comma(_st(_st(aMethod)._source())._asJavascript())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("messageSends: ").__comma(_st(_st(aMethod)._messageSends())._asJavascript())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+$2=_st($1)._nextPutAll_(_st("referencedClasses: ").__comma(_st(_st(aMethod)._referencedClasses())._asJavascript()));
|
|
|
|
+$3=aStream;
|
|
|
|
+_st($3)._lf();
|
|
|
|
+_st($3)._nextPutAll_("}),");
|
|
|
|
+_st($3)._lf();
|
|
|
|
+_st($3)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
+_st($3)._nextPutAll_(");");
|
|
|
|
+_st($3)._lf();
|
|
|
|
+$4=_st($3)._lf();
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.Exporter)})},
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "category", "compiledSource", "fn", "arguments", "source", "messageSends", "referencedClasses", "classNameFor:"],
|
|
messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "category", "compiledSource", "fn", "arguments", "source", "messageSends", "referencedClasses", "classNameFor:"],
|
|
@@ -267,17 +276,19 @@ selector: "exportMethodsOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-_st(_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
-})})))._do_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$1=_st(_st(each)._category())._match_("^\x5c*");
|
|
|
|
-if(! smalltalk.assert($1)){
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$2;
|
|
|
|
+$1=_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$2=(function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=_st(_st(each)._category())._match_("^\x5c*");
|
|
|
|
+if(! smalltalk.assert($3)){
|
|
return _st(self)._exportMethod_of_on_(each,aClass,aStream);
|
|
return _st(self)._exportMethod_of_on_(each,aClass,aStream);
|
|
};
|
|
};
|
|
-})}));
|
|
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._do_($2);
|
|
_st(aStream)._lf();
|
|
_st(aStream)._lf();
|
|
-return self}, self, "exportMethodsOf:on:", [aClass,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethodsOf:on:", [aClass,aStream], smalltalk.Exporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["do:", "ifFalse:", "exportMethod:of:on:", "match:", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "lf"],
|
|
messageSends: ["do:", "ifFalse:", "exportMethod:of:on:", "match:", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "lf"],
|
|
@@ -292,19 +303,19 @@ selector: "exportPackage:",
|
|
category: 'fileOut',
|
|
category: 'fileOut',
|
|
fn: function (packageName){
|
|
fn: function (packageName){
|
|
var self=this;
|
|
var self=this;
|
|
|
|
+var package_;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
-$ctx1.package=nil;
|
|
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
$1=_st((smalltalk.String || String))._streamContents_((function(stream){
|
|
-return smalltalk.withContext(function($ctx2) {
$ctx1.locals.package_=_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packageAt_(packageName);
|
|
|
|
-$ctx1.locals.package_;
|
|
|
|
-_st(self)._exportPackageDefinitionOf_on_($ctx1.locals.package_,stream);
|
|
|
|
-_st(_st(_st($ctx1.locals.package_)._sortedClasses())._asSet())._do_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx3) {
return _st(stream)._nextPutAll_(_st(self)._exportClass_(each));
|
|
|
|
-})}));
|
|
|
|
-return _st(self)._exportPackageExtensionsOf_on_($ctx1.locals.package_,stream);
|
|
|
|
-})}));
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
package_=_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._packageAt_(packageName);
|
|
|
|
+package_;
|
|
|
|
+_st(self)._exportPackageDefinitionOf_on_(package_,stream);
|
|
|
|
+_st(_st(_st(package_)._sortedClasses())._asSet())._do_((function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
return _st(stream)._nextPutAll_(_st(self)._exportClass_(each));
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})}));
|
|
|
|
+return _st(self)._exportPackageExtensionsOf_on_(package_,stream);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
return $1;
|
|
return $1;
|
|
-}, self, "exportPackage:", [packageName], smalltalk.Exporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"exportPackage:", [packageName], smalltalk.Exporter)})},
|
|
args: ["packageName"],
|
|
args: ["packageName"],
|
|
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]",
|
|
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]",
|
|
messageSends: ["streamContents:", "packageAt:", "current", "exportPackageDefinitionOf:on:", "do:", "nextPutAll:", "exportClass:", "asSet", "sortedClasses", "exportPackageExtensionsOf:on:"],
|
|
messageSends: ["streamContents:", "packageAt:", "current", "exportPackageDefinitionOf:on:", "do:", "nextPutAll:", "exportClass:", "asSet", "sortedClasses", "exportPackageExtensionsOf:on:"],
|
|
@@ -319,11 +330,12 @@ selector: "exportPackageDefinitionOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (package_,aStream){
|
|
fn: function (package_,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.addPackage(");
|
|
|
|
-$1=_st(aStream)._nextPutAll_(_st(_st(_st(_st("'").__comma(_st(package_)._name())).__comma("', ")).__comma(_st(package_)._propertiesAsJSON())).__comma(");"));
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.addPackage(");
|
|
|
|
+$2=_st($1)._nextPutAll_(_st(_st(_st(_st("'").__comma(_st(package_)._name())).__comma("', ")).__comma(_st(package_)._propertiesAsJSON())).__comma(");"));
|
|
_st(aStream)._lf();
|
|
_st(aStream)._lf();
|
|
-return self}, self, "exportPackageDefinitionOf:on:", [package_,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportPackageDefinitionOf:on:", [package_,aStream], smalltalk.Exporter)})},
|
|
args: ["package", "aStream"],
|
|
args: ["package", "aStream"],
|
|
source: "exportPackageDefinitionOf: package on: aStream\x0a\x09aStream \x0a\x09 nextPutAll: 'smalltalk.addPackage(';\x0a\x09 nextPutAll: '''', package name, ''', ', package propertiesAsJSON , ');'.\x0a\x09aStream lf",
|
|
source: "exportPackageDefinitionOf: package on: aStream\x0a\x09aStream \x0a\x09 nextPutAll: 'smalltalk.addPackage(';\x0a\x09 nextPutAll: '''', package name, ''', ', package propertiesAsJSON , ');'.\x0a\x09aStream lf",
|
|
messageSends: ["nextPutAll:", ",", "propertiesAsJSON", "name", "lf"],
|
|
messageSends: ["nextPutAll:", ",", "propertiesAsJSON", "name", "lf"],
|
|
@@ -338,22 +350,28 @@ selector: "exportPackageExtensionsOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (package_,aStream){
|
|
fn: function (package_,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-$ctx1.name=nil;
|
|
|
|
-$ctx1.locals.name=_st(package_)._name();
|
|
|
|
-_st(_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes()))._do_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st([each,_st(each)._class()])._do_((function(aClass){
|
|
|
|
-return smalltalk.withContext(function($ctx3) {
return _st(_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
|
|
|
|
-return smalltalk.withContext(function($ctx4) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
-})})))._do_((function(method){
|
|
|
|
-return smalltalk.withContext(function($ctx4) {
$1=_st(_st(method)._category())._match_(_st("^\x5c*").__comma($ctx1.locals.name));
|
|
|
|
-if(smalltalk.assert($1)){
|
|
|
|
|
|
+var name;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$5,$7,$6,$4,$2;
|
|
|
|
+name=_st(package_)._name();
|
|
|
|
+$1=_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes());
|
|
|
|
+$2=(function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=[each,_st(each)._class()];
|
|
|
|
+$4=(function(aClass){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
$5=_st(_st(_st(aClass)._methodDictionary())._values())._sorted_((function(a,b){
|
|
|
|
+return smalltalk.withContext(function($ctx4) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
+}, function($ctx4) {$ctx4.fill(null, null, {})})}));
|
|
|
|
+$6=(function(method){
|
|
|
|
+return smalltalk.withContext(function($ctx4) {
$7=_st(_st(method)._category())._match_(_st("^\x5c*").__comma(name));
|
|
|
|
+if(smalltalk.assert($7)){
|
|
return _st(self)._exportMethod_of_on_(method,aClass,aStream);
|
|
return _st(self)._exportMethod_of_on_(method,aClass,aStream);
|
|
};
|
|
};
|
|
-})}));
|
|
|
|
-})}));
|
|
|
|
-})}));
|
|
|
|
-return self}, self, "exportPackageExtensionsOf:on:", [package_,aStream], smalltalk.Exporter)},
|
|
|
|
|
|
+}, function($ctx4) {$ctx4.fill(null, null, {})})});
|
|
|
|
+return _st($5)._do_($6);
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})});
|
|
|
|
+return _st($3)._do_($4);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._do_($2);
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportPackageExtensionsOf:on:", [package_,aStream], smalltalk.Exporter)})},
|
|
args: ["package", "aStream"],
|
|
args: ["package", "aStream"],
|
|
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 ]]]]",
|
|
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 ]]]]",
|
|
messageSends: ["name", "do:", "ifTrue:", "exportMethod:of:on:", "match:", ",", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "class", "sortedClasses:", "classes", "current"],
|
|
messageSends: ["name", "do:", "ifTrue:", "exportMethod:of:on:", "match:", ",", "category", "sorted:", "<=", "selector", "values", "methodDictionary", "class", "sortedClasses:", "classes", "current"],
|
|
@@ -374,7 +392,7 @@ var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
$1=_st(_st(aString)._replace_with_("!","!!"))._trimBoth();
|
|
$1=_st(_st(aString)._replace_with_("!","!!"))._trimBoth();
|
|
return $1;
|
|
return $1;
|
|
-}, self, "chunkEscape:", [aString], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"chunkEscape:", [aString], smalltalk.ChunkExporter)})},
|
|
args: ["aString"],
|
|
args: ["aString"],
|
|
source: "chunkEscape: aString\x0a\x09\x22Replace all occurrences of ! with !! and trim at both ends.\x22\x0a\x0a\x09^(aString replace: '!' with: '!!') trimBoth",
|
|
source: "chunkEscape: aString\x0a\x09\x22Replace all occurrences of ! with !! and trim at both ends.\x22\x0a\x0a\x09^(aString replace: '!' with: '!!') trimBoth",
|
|
messageSends: ["trimBoth", "replace:with:"],
|
|
messageSends: ["trimBoth", "replace:with:"],
|
|
@@ -389,20 +407,22 @@ selector: "classNameFor:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (aClass){
|
|
fn: function (aClass){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $2,$3,$1;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $2,$3,$5,$4,$1;
|
|
$2=_st(aClass)._isMetaclass();
|
|
$2=_st(aClass)._isMetaclass();
|
|
-if(smalltalk.assert($2)){
|
|
|
|
-$1=_st(_st(_st(aClass)._instanceClass())._name()).__comma(" class");
|
|
|
|
|
|
+$3=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(_st(_st(aClass)._instanceClass())._name()).__comma(" class");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$4=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$5=_st(aClass)._isNil();
|
|
|
|
+if(smalltalk.assert($5)){
|
|
|
|
+return "nil";
|
|
} else {
|
|
} else {
|
|
-$3=_st(aClass)._isNil();
|
|
|
|
-if(smalltalk.assert($3)){
|
|
|
|
-$1="nil";
|
|
|
|
-} else {
|
|
|
|
-$1=_st(aClass)._name();
|
|
|
|
-};
|
|
|
|
|
|
+return _st(aClass)._name();
|
|
};
|
|
};
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$1=_st($2)._ifTrue_ifFalse_($3,$4);
|
|
return $1;
|
|
return $1;
|
|
-}, self, "classNameFor:", [aClass], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"classNameFor:", [aClass], smalltalk.ChunkExporter)})},
|
|
args: ["aClass"],
|
|
args: ["aClass"],
|
|
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]]",
|
|
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]]",
|
|
messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
|
|
messageSends: ["ifTrue:ifFalse:", ",", "name", "instanceClass", "isNil", "isMetaclass"],
|
|
@@ -417,30 +437,33 @@ selector: "exportDefinitionOf:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4;
|
|
|
|
-_st(aStream)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._superclass()));
|
|
|
|
-_st(aStream)._nextPutAll_(_st(" subclass: #").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$1=_st(aStream)._nextPutAll_("\x09instanceVariableNames: '");
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4,$5,$6,$7;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._superclass()));
|
|
|
|
+_st($1)._nextPutAll_(_st(" subclass: #").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+$2=_st($1)._nextPutAll_("\x09instanceVariableNames: '");
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(each);
|
|
|
|
-})}),(function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(" ");
|
|
|
|
-})}));
|
|
|
|
-_st(aStream)._nextPutAll_("'");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("\x09package: '").__comma(_st(aClass)._category())).__comma("'!"));
|
|
|
|
-$2=_st(aStream)._lf();
|
|
|
|
-$3=_st(_st(aClass)._comment())._notEmpty();
|
|
|
|
-if(smalltalk.assert($3)){
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("!").__comma(_st(self)._classNameFor_(aClass))).__comma(" commentStamp!"));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(self)._chunkEscape_(_st(aClass)._comment())).__comma("!"));
|
|
|
|
-$4=_st(aStream)._lf();
|
|
|
|
-$4;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(each);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}),(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(" ");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$3=aStream;
|
|
|
|
+_st($3)._nextPutAll_("'");
|
|
|
|
+_st($3)._lf();
|
|
|
|
+_st($3)._nextPutAll_(_st(_st("\x09package: '").__comma(_st(aClass)._category())).__comma("'!"));
|
|
|
|
+$4=_st($3)._lf();
|
|
|
|
+$5=_st(_st(aClass)._comment())._notEmpty();
|
|
|
|
+if(smalltalk.assert($5)){
|
|
|
|
+$6=aStream;
|
|
|
|
+_st($6)._nextPutAll_(_st(_st("!").__comma(_st(self)._classNameFor_(aClass))).__comma(" commentStamp!"));
|
|
|
|
+_st($6)._lf();
|
|
|
|
+_st($6)._nextPutAll_(_st(_st(self)._chunkEscape_(_st(aClass)._comment())).__comma("!"));
|
|
|
|
+$7=_st($6)._lf();
|
|
|
|
+$7;
|
|
};
|
|
};
|
|
_st(aStream)._lf();
|
|
_st(aStream)._lf();
|
|
-return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", "classNameFor:", "superclass", ",", "lf", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "chunkEscape:", "comment", "notEmpty"],
|
|
messageSends: ["nextPutAll:", "classNameFor:", "superclass", ",", "lf", "do:separatedBy:", "instanceVariableNames", "category", "ifTrue:", "chunkEscape:", "comment", "notEmpty"],
|
|
@@ -455,23 +478,25 @@ selector: "exportMetaDefinitionOf:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2,$3;
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4,$5;
|
|
$1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
|
|
$1=_st(_st(_st(aClass)._class())._instanceVariableNames())._isEmpty();
|
|
if(! smalltalk.assert($1)){
|
|
if(! smalltalk.assert($1)){
|
|
-_st(aStream)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._class()));
|
|
|
|
-$2=_st(aStream)._nextPutAll_(" instanceVariableNames: '");
|
|
|
|
-$2;
|
|
|
|
-_st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(each);
|
|
|
|
-})}),(function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(" ");
|
|
|
|
-})}));
|
|
|
|
-_st(aStream)._nextPutAll_("'!");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$3=_st(aStream)._lf();
|
|
|
|
|
|
+$2=aStream;
|
|
|
|
+_st($2)._nextPutAll_(_st(self)._classNameFor_(_st(aClass)._class()));
|
|
|
|
+$3=_st($2)._nextPutAll_(" instanceVariableNames: '");
|
|
$3;
|
|
$3;
|
|
|
|
+_st(_st(_st(aClass)._class())._instanceVariableNames())._do_separatedBy_((function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(each);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}),(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(" ");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$4=aStream;
|
|
|
|
+_st($4)._nextPutAll_("'!");
|
|
|
|
+_st($4)._lf();
|
|
|
|
+$5=_st($4)._lf();
|
|
|
|
+$5;
|
|
};
|
|
};
|
|
-return self}, self, "exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMetaDefinitionOf:on:", [aClass,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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]",
|
|
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]",
|
|
messageSends: ["ifFalse:", "nextPutAll:", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
|
|
messageSends: ["ifFalse:", "nextPutAll:", "classNameFor:", "class", "do:separatedBy:", "instanceVariableNames", "lf", "isEmpty"],
|
|
@@ -486,13 +511,14 @@ selector: "exportMethod:of:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (aMethod,aClass,aStream){
|
|
fn: function (aMethod,aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(self)._chunkEscape_(_st(aMethod)._source()));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$1=_st(aStream)._nextPutAll_("!");
|
|
|
|
-return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(self)._chunkEscape_(_st(aMethod)._source()));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+$2=_st($1)._nextPutAll_("!");
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
source: "exportMethod: aMethod of: aClass on: aStream\x0a\x09aStream \x0a\x09\x09lf; lf; nextPutAll: (self chunkEscape: aMethod source); lf;\x0a\x09\x09nextPutAll: '!'",
|
|
source: "exportMethod: aMethod of: aClass on: aStream\x0a\x09aStream \x0a\x09\x09lf; lf; nextPutAll: (self chunkEscape: aMethod source); lf;\x0a\x09\x09nextPutAll: '!'",
|
|
messageSends: ["lf", "nextPutAll:", "chunkEscape:", "source"],
|
|
messageSends: ["lf", "nextPutAll:", "chunkEscape:", "source"],
|
|
@@ -507,18 +533,20 @@ selector: "exportMethods:category:of:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (methods,category,aClass,aStream){
|
|
fn: function (methods,category,aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
-_st(aStream)._nextPutAll_(_st("!").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
-$1=_st(aStream)._nextPutAll_(_st(_st(" methodsFor: '").__comma(category)).__comma("'!"));
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_(_st("!").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
+$2=_st($1)._nextPutAll_(_st(_st(" methodsFor: '").__comma(category)).__comma("'!"));
|
|
_st(_st(methods)._sorted_((function(a,b){
|
|
_st(_st(methods)._sorted_((function(a,b){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
-})})))._do_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(self)._exportMethod_of_on_(each,aClass,aStream);
|
|
|
|
-})}));
|
|
|
|
-_st(aStream)._nextPutAll_(" !");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$2=_st(aStream)._lf();
|
|
|
|
-return self}, self, "exportMethods:category:of:on:", [methods,category,aClass,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(_st(a)._selector()).__lt_eq(_st(b)._selector());
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})})))._do_((function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(self)._exportMethod_of_on_(each,aClass,aStream);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$3=aStream;
|
|
|
|
+_st($3)._nextPutAll_(" !");
|
|
|
|
+_st($3)._lf();
|
|
|
|
+$4=_st($3)._lf();
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethods:category:of:on:", [methods,category,aClass,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["methods", "category", "aClass", "aStream"],
|
|
args: ["methods", "category", "aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "do:", "exportMethod:of:on:", "sorted:", "<=", "selector", "lf"],
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "do:", "exportMethod:of:on:", "sorted:", "<=", "selector", "lf"],
|
|
@@ -533,24 +561,25 @@ selector: "exportMethodsOf:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-$ctx1.map=nil;
|
|
|
|
-$ctx1.locals.map=_st((smalltalk.Dictionary || Dictionary))._new();
|
|
|
|
-_st(aClass)._protocolsDo_((function(category,methods){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$1=_st(category)._match_("^\x5c*");
|
|
|
|
-if(! smalltalk.assert($1)){
|
|
|
|
-return _st($ctx1.locals.map)._at_put_(category,methods);
|
|
|
|
|
|
+var map;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$2;
|
|
|
|
+map=_st((smalltalk.Dictionary || Dictionary))._new();
|
|
|
|
+$1=aClass;
|
|
|
|
+$2=(function(category,methods){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=_st(category)._match_("^\x5c*");
|
|
|
|
+if(! smalltalk.assert($3)){
|
|
|
|
+return _st(map)._at_put_(category,methods);
|
|
};
|
|
};
|
|
-})}));
|
|
|
|
-_st(_st(_st($ctx1.locals.map)._keys())._sorted_((function(a,b){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(a).__lt_eq(b);
|
|
|
|
-})})))._do_((function(category){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$ctx2.methods=nil;
|
|
|
|
-$ctx2.locals.methods=_st($ctx1.locals.map)._at_(category);
|
|
|
|
-$ctx2.locals.methods;
|
|
|
|
-return _st(self)._exportMethods_category_of_on_($ctx2.locals.methods,category,aClass,aStream);
|
|
|
|
-})}));
|
|
|
|
-return self}, self, "exportMethodsOf:on:", [aClass,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._protocolsDo_($2);
|
|
|
|
+_st(_st(_st(map)._keys())._sorted_((function(a,b){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(a).__lt_eq(b);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})})))._do_((function(category){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
methods=_st(map)._at_(category);
|
|
|
|
+methods;
|
|
|
|
+return _st(self)._exportMethods_category_of_on_(methods,category,aClass,aStream);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethodsOf:on:", [aClass,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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 ]",
|
|
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 ]",
|
|
messageSends: ["new", "protocolsDo:", "ifFalse:", "at:put:", "match:", "do:", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys"],
|
|
messageSends: ["new", "protocolsDo:", "ifFalse:", "at:put:", "match:", "do:", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys"],
|
|
@@ -565,10 +594,11 @@ selector: "exportPackageDefinitionOf:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (package_,aStream){
|
|
fn: function (package_,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(_st(_st("Smalltalk current createPackage: '").__comma(_st(package_)._name())).__comma("' properties: ")).__comma(_st(_st(package_)._properties())._storeString())).__comma("!"));
|
|
|
|
-$1=_st(aStream)._lf();
|
|
|
|
-return self}, self, "exportPackageDefinitionOf:on:", [package_,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_(_st(_st(_st(_st("Smalltalk current createPackage: '").__comma(_st(package_)._name())).__comma("' properties: ")).__comma(_st(_st(package_)._properties())._storeString())).__comma("!"));
|
|
|
|
+$2=_st($1)._lf();
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportPackageDefinitionOf:on:", [package_,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["package", "aStream"],
|
|
args: ["package", "aStream"],
|
|
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.",
|
|
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.",
|
|
messageSends: ["nextPutAll:", ",", "storeString", "properties", "name", "lf"],
|
|
messageSends: ["nextPutAll:", ",", "storeString", "properties", "name", "lf"],
|
|
@@ -583,31 +613,35 @@ selector: "exportPackageExtensionsOf:on:",
|
|
category: 'not yet classified',
|
|
category: 'not yet classified',
|
|
fn: function (package_,aStream){
|
|
fn: function (package_,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-$ctx1.name=nil;
|
|
|
|
-$ctx1.map=nil;
|
|
|
|
-$ctx1.locals.name=_st(package_)._name();
|
|
|
|
-_st(_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes()))._do_((function(each){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st([each,_st(each)._class()])._do_((function(aClass){
|
|
|
|
-return smalltalk.withContext(function($ctx3) {
$ctx1.locals.map=_st((smalltalk.Dictionary || Dictionary))._new();
|
|
|
|
-$ctx1.locals.map;
|
|
|
|
-_st(aClass)._protocolsDo_((function(category,methods){
|
|
|
|
-return smalltalk.withContext(function($ctx4) {
$1=_st(category)._match_(_st("^\x5c*").__comma($ctx1.locals.name));
|
|
|
|
-if(smalltalk.assert($1)){
|
|
|
|
-return _st($ctx1.locals.map)._at_put_(category,methods);
|
|
|
|
|
|
+var name,map;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$5,$7,$6,$4,$2;
|
|
|
|
+name=_st(package_)._name();
|
|
|
|
+$1=_st((smalltalk.Package || Package))._sortedClasses_(_st(_st((smalltalk.Smalltalk || Smalltalk))._current())._classes());
|
|
|
|
+$2=(function(each){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=[each,_st(each)._class()];
|
|
|
|
+$4=(function(aClass){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
map=_st((smalltalk.Dictionary || Dictionary))._new();
|
|
|
|
+map;
|
|
|
|
+$5=aClass;
|
|
|
|
+$6=(function(category,methods){
|
|
|
|
+return smalltalk.withContext(function($ctx4) {
$7=_st(category)._match_(_st("^\x5c*").__comma(name));
|
|
|
|
+if(smalltalk.assert($7)){
|
|
|
|
+return _st(map)._at_put_(category,methods);
|
|
};
|
|
};
|
|
-})}));
|
|
|
|
-return _st(_st(_st($ctx1.locals.map)._keys())._sorted_((function(a,b){
|
|
|
|
-return smalltalk.withContext(function($ctx4) {
return _st(a).__lt_eq(b);
|
|
|
|
-})})))._do_((function(category){
|
|
|
|
-return smalltalk.withContext(function($ctx4) {
$ctx4.methods=nil;
|
|
|
|
-$ctx4.locals.methods=_st($ctx1.locals.map)._at_(category);
|
|
|
|
-$ctx4.locals.methods;
|
|
|
|
-return _st(self)._exportMethods_category_of_on_($ctx4.locals.methods,category,aClass,aStream);
|
|
|
|
-})}));
|
|
|
|
-})}));
|
|
|
|
-})}));
|
|
|
|
-return self}, self, "exportPackageExtensionsOf:on:", [package_,aStream], smalltalk.ChunkExporter)},
|
|
|
|
|
|
+}, function($ctx4) {$ctx4.fill(null, null, {})})});
|
|
|
|
+_st($5)._protocolsDo_($6);
|
|
|
|
+return _st(_st(_st(map)._keys())._sorted_((function(a,b){
|
|
|
|
+return smalltalk.withContext(function($ctx4) {
return _st(a).__lt_eq(b);
|
|
|
|
+}, function($ctx4) {$ctx4.fill(null, null, {})})})))._do_((function(category){
|
|
|
|
+return smalltalk.withContext(function($ctx4) {
methods=_st(map)._at_(category);
|
|
|
|
+methods;
|
|
|
|
+return _st(self)._exportMethods_category_of_on_(methods,category,aClass,aStream);
|
|
|
|
+}, function($ctx4) {$ctx4.fill(null, null, {})})}));
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})});
|
|
|
|
+return _st($3)._do_($4);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._do_($2);
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportPackageExtensionsOf:on:", [package_,aStream], smalltalk.ChunkExporter)})},
|
|
args: ["package", "aStream"],
|
|
args: ["package", "aStream"],
|
|
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 ]]]",
|
|
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 ]]]",
|
|
messageSends: ["name", "do:", "new", "protocolsDo:", "ifTrue:", "at:put:", "match:", ",", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys", "class", "sortedClasses:", "classes", "current"],
|
|
messageSends: ["name", "do:", "new", "protocolsDo:", "ifTrue:", "at:put:", "match:", ",", "at:", "exportMethods:category:of:on:", "sorted:", "<=", "keys", "class", "sortedClasses:", "classes", "current"],
|
|
@@ -625,21 +659,23 @@ selector: "exportDefinitionOf:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aClass,aStream){
|
|
fn: function (aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.addClass(");
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
|
|
|
|
-_st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
|
|
|
|
-$1=_st(aStream)._nextPutAll_(", [");
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$3,$4;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.addClass(");
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("'").__comma(_st(self)._classNameFor_(aClass))).__comma("', "));
|
|
|
|
+_st($1)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(_st(aClass)._superclass())));
|
|
|
|
+$2=_st($1)._nextPutAll_(", [");
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
_st(_st(aClass)._instanceVariableNames())._do_separatedBy_((function(each){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
-})}),(function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(", ");
|
|
|
|
-})}));
|
|
|
|
-_st(aStream)._nextPutAll_("], '");
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
|
|
|
|
-$2=_st(aStream)._nextPutAll_(");");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-return self}, self, "exportDefinitionOf:on:", [aClass,aStream], smalltalk.StrippedExporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(_st(_st("'").__comma(each)).__comma("'"));
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}),(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(aStream)._nextPutAll_(", ");
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+$3=aStream;
|
|
|
|
+_st($3)._nextPutAll_("], '");
|
|
|
|
+_st($3)._nextPutAll_(_st(_st(aClass)._category()).__comma("'"));
|
|
|
|
+$4=_st($3)._nextPutAll_(");");
|
|
|
|
+_st(aStream)._lf();
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportDefinitionOf:on:", [aClass,aStream], smalltalk.StrippedExporter)})},
|
|
args: ["aClass", "aStream"],
|
|
args: ["aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "lf"],
|
|
messageSends: ["nextPutAll:", ",", "classNameFor:", "superclass", "do:separatedBy:", "instanceVariableNames", "category", "lf"],
|
|
@@ -654,24 +690,25 @@ selector: "exportMethod:of:on:",
|
|
category: 'private',
|
|
category: 'private',
|
|
fn: function (aMethod,aClass,aStream){
|
|
fn: function (aMethod,aClass,aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.addMethod(");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_("smalltalk.method({");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource()));
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_("}),");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-_st(aStream)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
-_st(aStream)._nextPutAll_(");");
|
|
|
|
-_st(aStream)._lf();
|
|
|
|
-$1=_st(aStream)._lf();
|
|
|
|
-return self}, self, "exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.StrippedExporter)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2;
|
|
|
|
+$1=aStream;
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.addMethod(");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st(_st(_st(aMethod)._selector())._asSelector())._asJavascript()).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_("smalltalk.method({");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st(_st("selector: ").__comma(_st(_st(aMethod)._selector())._asJavascript())).__comma(","));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st("fn: ").__comma(_st(_st(aMethod)._fn())._compiledSource()));
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_("}),");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+_st($1)._nextPutAll_(_st("smalltalk.").__comma(_st(self)._classNameFor_(aClass)));
|
|
|
|
+_st($1)._nextPutAll_(");");
|
|
|
|
+_st($1)._lf();
|
|
|
|
+$2=_st($1)._lf();
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"exportMethod:of:on:", [aMethod,aClass,aStream], smalltalk.StrippedExporter)})},
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
args: ["aMethod", "aClass", "aStream"],
|
|
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",
|
|
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",
|
|
messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "compiledSource", "fn", "classNameFor:"],
|
|
messageSends: ["nextPutAll:", "lf", ",", "asJavascript", "asSelector", "selector", "compiledSource", "fn", "classNameFor:"],
|
|
@@ -689,33 +726,35 @@ selector: "import:",
|
|
category: 'fileIn',
|
|
category: 'fileIn',
|
|
fn: function (aStream){
|
|
fn: function (aStream){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-$ctx1.chunk=nil;
|
|
|
|
-$ctx1.result=nil;
|
|
|
|
-$ctx1.parser=nil;
|
|
|
|
-$ctx1.lastEmpty=nil;
|
|
|
|
-$ctx1.locals.parser=_st((smalltalk.ChunkParser || ChunkParser))._on_(aStream);
|
|
|
|
-$ctx1.locals.lastEmpty=false;
|
|
|
|
-_st((function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$ctx1.locals.chunk=_st($ctx1.locals.parser)._nextChunk();
|
|
|
|
-$ctx1.locals.chunk;
|
|
|
|
-return _st($ctx1.locals.chunk)._isNil();
|
|
|
|
-})}))._whileFalse_((function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$1=_st($ctx1.locals.chunk)._isEmpty();
|
|
|
|
-if(smalltalk.assert($1)){
|
|
|
|
-$ctx1.locals.lastEmpty=true;
|
|
|
|
-return $ctx1.locals.lastEmpty;
|
|
|
|
-} else {
|
|
|
|
-$ctx1.locals.result=_st(_st((smalltalk.Compiler || Compiler))._new())._evaluateExpression_($ctx1.locals.chunk);
|
|
|
|
-$ctx1.locals.result;
|
|
|
|
-if(smalltalk.assert($ctx1.locals.lastEmpty)){
|
|
|
|
-$ctx1.locals.lastEmpty=false;
|
|
|
|
-$ctx1.locals.lastEmpty;
|
|
|
|
-return _st($ctx1.locals.result)._scanFrom_($ctx1.locals.parser);
|
|
|
|
|
|
+var chunk,result,parser,lastEmpty;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$3,$4,$6,$5,$2;
|
|
|
|
+parser=_st((smalltalk.ChunkParser || ChunkParser))._on_(aStream);
|
|
|
|
+lastEmpty=false;
|
|
|
|
+$1=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
chunk=_st(parser)._nextChunk();
|
|
|
|
+chunk;
|
|
|
|
+return _st(chunk)._isNil();
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$2=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$3=_st(chunk)._isEmpty();
|
|
|
|
+$4=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
lastEmpty=true;
|
|
|
|
+return lastEmpty;
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})});
|
|
|
|
+$5=(function(){
|
|
|
|
+return smalltalk.withContext(function($ctx3) {
result=_st(_st((smalltalk.Compiler || Compiler))._new())._evaluateExpression_(chunk);
|
|
|
|
+result;
|
|
|
|
+$6=lastEmpty;
|
|
|
|
+if(smalltalk.assert($6)){
|
|
|
|
+lastEmpty=false;
|
|
|
|
+lastEmpty;
|
|
|
|
+return _st(result)._scanFrom_(parser);
|
|
};
|
|
};
|
|
-};
|
|
|
|
-})}));
|
|
|
|
-return self}, self, "import:", [aStream], smalltalk.Importer)},
|
|
|
|
|
|
+}, function($ctx3) {$ctx3.fill(null, null, {})})});
|
|
|
|
+return _st($3)._ifTrue_ifFalse_($4,$5);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+_st($1)._whileFalse_($2);
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"import:", [aStream], smalltalk.Importer)})},
|
|
args: ["aStream"],
|
|
args: ["aStream"],
|
|
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]]]",
|
|
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]]]",
|
|
messageSends: ["on:", "whileFalse:", "ifTrue:ifFalse:", "evaluateExpression:", "new", "ifTrue:", "scanFrom:", "isEmpty", "nextChunk", "isNil"],
|
|
messageSends: ["on:", "whileFalse:", "ifTrue:ifFalse:", "evaluateExpression:", "new", "ifTrue:", "scanFrom:", "isEmpty", "nextChunk", "isNil"],
|
|
@@ -738,7 +777,7 @@ $1=_st((smalltalk.Package || Package))._named_(packageName);
|
|
_st($1)._setupClasses();
|
|
_st($1)._setupClasses();
|
|
_st($1)._commitPathJs_(_st(_st("/").__comma(aString)).__comma("/js"));
|
|
_st($1)._commitPathJs_(_st(_st("/").__comma(aString)).__comma("/js"));
|
|
$2=_st($1)._commitPathSt_(_st(_st("/").__comma(aString)).__comma("/st"));
|
|
$2=_st($1)._commitPathSt_(_st(_st("/").__comma(aString)).__comma("/st"));
|
|
-return self}, self, "initializePackageNamed:prefix:", [packageName,aString], smalltalk.PackageLoader)},
|
|
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"initializePackageNamed:prefix:", [packageName,aString], smalltalk.PackageLoader)})},
|
|
args: ["packageName", "aString"],
|
|
args: ["packageName", "aString"],
|
|
source: "initializePackageNamed: packageName prefix: aString\x0a\x0a\x09(Package named: packageName) \x0a \x09setupClasses;\x0a commitPathJs: '/', aString, '/js';\x0a commitPathSt: '/', aString, '/st'",
|
|
source: "initializePackageNamed: packageName prefix: aString\x0a\x0a\x09(Package named: packageName) \x0a \x09setupClasses;\x0a commitPathJs: '/', aString, '/js';\x0a commitPathSt: '/', aString, '/st'",
|
|
messageSends: ["setupClasses", "named:", "commitPathJs:", ",", "commitPathSt:"],
|
|
messageSends: ["setupClasses", "named:", "commitPathJs:", ",", "commitPathSt:"],
|
|
@@ -753,18 +792,25 @@ selector: "loadPackage:prefix:",
|
|
category: 'laoding',
|
|
category: 'laoding',
|
|
fn: function (packageName,aString){
|
|
fn: function (packageName,aString){
|
|
var self=this;
|
|
var self=this;
|
|
-return smalltalk.withContext(function($ctx1) {
var $1;
|
|
|
|
-$ctx1.url=nil;
|
|
|
|
-$ctx1.locals.url=_st(_st(_st(_st("/").__comma(aString)).__comma("/js/")).__comma(packageName)).__comma(".js");
|
|
|
|
-_st(jQuery)._ajax_options_($ctx1.locals.url,smalltalk.HashedCollection._fromPairs_([_st("type").__minus_gt("GET"),_st("dataType").__minus_gt("script"),_st("complete").__minus_gt((function(jqXHR,textStatus){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
$1=_st(_st(jqXHR)._readyState()).__eq((4));
|
|
|
|
-if(smalltalk.assert($1)){
|
|
|
|
|
|
+var url;
|
|
|
|
+return smalltalk.withContext(function($ctx1) {
var $1,$2,$4,$5,$8,$7,$6,$3;
|
|
|
|
+url=_st(_st(_st(_st("/").__comma(aString)).__comma("/js/")).__comma(packageName)).__comma(".js");
|
|
|
|
+$1=jQuery;
|
|
|
|
+$2=url;
|
|
|
|
+$4=_st("type").__minus_gt("GET");
|
|
|
|
+$5=_st("dataType").__minus_gt("script");
|
|
|
|
+$7=(function(jqXHR,textStatus){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
$8=_st(_st(jqXHR)._readyState()).__eq((4));
|
|
|
|
+if(smalltalk.assert($8)){
|
|
return _st(self)._initializePackageNamed_prefix_(packageName,aString);
|
|
return _st(self)._initializePackageNamed_prefix_(packageName,aString);
|
|
};
|
|
};
|
|
-})})),_st("error").__minus_gt((function(){
|
|
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(window)._alert_(_st("Could not load package at: ").__comma($ctx1.locals.url));
|
|
|
|
-})}))]));
|
|
|
|
-return self}, self, "loadPackage:prefix:", [packageName,aString], smalltalk.PackageLoader)},
|
|
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})});
|
|
|
|
+$6=_st("complete").__minus_gt($7);
|
|
|
|
+$3=smalltalk.HashedCollection._fromPairs_([$4,$5,$6,_st("error").__minus_gt((function(){
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(window)._alert_(_st("Could not load package at: ").__comma(url));
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}))]);
|
|
|
|
+_st($1)._ajax_options_($2,$3);
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"loadPackage:prefix:", [packageName,aString], smalltalk.PackageLoader)})},
|
|
args: ["packageName", "aString"],
|
|
args: ["packageName", "aString"],
|
|
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}",
|
|
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}",
|
|
messageSends: [",", "ajax:options:", "->", "ifTrue:", "initializePackageNamed:prefix:", "=", "readyState", "alert:"],
|
|
messageSends: [",", "ajax:options:", "->", "ifTrue:", "initializePackageNamed:prefix:", "=", "readyState", "alert:"],
|
|
@@ -780,9 +826,9 @@ category: 'laoding',
|
|
fn: function (aCollection,aString){
|
|
fn: function (aCollection,aString){
|
|
var self=this;
|
|
var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
_st(aCollection)._do_((function(each){
|
|
return smalltalk.withContext(function($ctx1) {
_st(aCollection)._do_((function(each){
|
|
-return smalltalk.withContext(function($ctx2) {
return _st(self)._loadPackage_prefix_(each,aString);
|
|
|
|
-})}));
|
|
|
|
-return self}, self, "loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader)},
|
|
|
|
|
|
+return smalltalk.withContext(function($ctx2) {
return _st(self)._loadPackage_prefix_(each,aString);
|
|
|
|
+}, function($ctx2) {$ctx2.fill(null, null, {})})}));
|
|
|
|
+return self}, function($ctx1) {$ctx1.fill(self,"loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader)})},
|
|
args: ["aCollection", "aString"],
|
|
args: ["aCollection", "aString"],
|
|
source: "loadPackages: aCollection prefix: aString\x0a\x09aCollection do: [ :each |\x0a \x09self loadPackage: each prefix: aString ]",
|
|
source: "loadPackages: aCollection prefix: aString\x0a\x09aCollection do: [ :each |\x0a \x09self loadPackage: each prefix: aString ]",
|
|
messageSends: ["do:", "loadPackage:prefix:"],
|
|
messageSends: ["do:", "loadPackage:prefix:"],
|
|
@@ -801,7 +847,7 @@ var self=this;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
return smalltalk.withContext(function($ctx1) {
var $1;
|
|
$1=_st(_st(self)._new())._loadPackages_prefix_(aCollection,aString);
|
|
$1=_st(_st(self)._new())._loadPackages_prefix_(aCollection,aString);
|
|
return $1;
|
|
return $1;
|
|
-}, self, "loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader.klass)},
|
|
|
|
|
|
+}, function($ctx1) {$ctx1.fill(self,"loadPackages:prefix:", [aCollection,aString], smalltalk.PackageLoader.klass)})},
|
|
args: ["aCollection", "aString"],
|
|
args: ["aCollection", "aString"],
|
|
source: "loadPackages: aCollection prefix: aString\x0a\x09^ self new loadPackages: aCollection prefix: aString",
|
|
source: "loadPackages: aCollection prefix: aString\x0a\x09^ self new loadPackages: aCollection prefix: aString",
|
|
messageSends: ["loadPackages:prefix:", "new"],
|
|
messageSends: ["loadPackages:prefix:", "new"],
|