Silk.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438
  1. define(["amber/boot", "require", "amber/core/Kernel-Collections", "amber/core/Kernel-Infrastructure", "amber/core/Kernel-Methods", "amber/core/Kernel-Objects", "domite/DOMite"], function($boot,requirejs){"use strict";
  2. var $core=$boot.api,nil=$boot.nilAsValue,$nil=$boot.nilAsReceiver,$recv=$boot.asReceiver,$globals=$boot.globals;
  3. var $pkg = $core.addPackage("Silk");
  4. $pkg.innerEval = function (expr) { return eval(expr); };
  5. $pkg.transport = {"type":"amd","amdNamespace":"silk"};
  6. $core.addClass("Silk", $globals.Domite, [], "Silk");
  7. //>>excludeStart("ide", pragmas.excludeIdeData);
  8. $globals.Silk.comment="I am subclass of `Domite` with more convenient high-level API.\x0a\x0a##Rendering\x0a\x0a - `aSilk << anObject` uses double-dispatch via `renderOnSilk:`.\x0aThis allows to create widgets\x0a(no formal superclass, anything with `renderOnSilk:` is a widget),\x0aas well as incorporating magic on certain types of objects:\x0a - blocks: `aSilk << aBlock` runs the block, passing aSilk as a parameter.\x0a - associations: `aSilk << (key -> value)` set attribute key to value.\x0a\x0aWorthful to note is, rendering a collection has its magic\x0aalready built-in (via `putOn:`) -- if you `stream << aCollection`,\x0aits items are `<<`'d in sequence.\x0aSo, de facto, arrays are deeply flattened when put on a stream via `<<`.\x0a\x0a##Convenience\x0a\x0a - `aCssSelectorString asSilk` returns Silk wrapping an element at a selector.\x0a - `anObject inSilk` returns anObject rendered in a document fragment.\x0a\x0a##Element creation\x0a\x0aThese messages use DNU to dynamically create\x0aelements with any (letters-and-numbers) tag name,\x0aNext samples show this on an example of `<div>`.\x0a\x0a - `Silk DIV` is shortcut for `Silk newElement: 'div'`.\x0a - `aSilk DIV` is shortcut for\x0a`[ |tmp| tmp := Silk DIV. aSilk << tmp. tmp] value`.\x0aIOW, it not just creates the element and returns it,\x0abut also puts in on aSilk.\x0a - `aSilk DIV: anObject` is shortcut for\x0a`aSilk DIV << anObject; yourself`.\x0aIOW, it not just creates and inserts the element,\x0abut puts a content into it.\x0a\x0a##Conclusions\x0a\x0aTaken all this together, one can do pretty neat constructs:\x0a\x0a```\x0a aSilk P: { 'id'->'mission'. 'We are the champions.' }\x0a```\x0a\x0aadds `<p id=\x22mission\x22>We are the champions.</p>` into `aSilk`\x0aand returns the Silk-wrapped `<p>` with insertion cursor at the end.";
  9. //>>excludeEnd("ide");
  10. $core.addMethod(
  11. $core.method({
  12. selector: "namespace",
  13. protocol: "accessing",
  14. //>>excludeStart("ide", pragmas.excludeIdeData);
  15. args: [],
  16. source: "namespace\x0a\x09\x22<String>\x0a\x09XML namespace for elements: html.\x0a\x09The default for all virtual Silk tag messages\x22\x0a\x09\x0a\x09^ self element namespaceURI",
  17. referencedClasses: [],
  18. //>>excludeEnd("ide");
  19. pragmas: [],
  20. messageSends: ["namespaceURI", "element"]
  21. }, function ($methodClass){ return function (){
  22. var self=this,$self=this;
  23. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  24. return $core.withContext(function($ctx1) {
  25. //>>excludeEnd("ctx");
  26. return $recv($self._element())._namespaceURI();
  27. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  28. }, function($ctx1) {$ctx1.fill(self,"namespace",{})});
  29. //>>excludeEnd("ctx");
  30. }; }),
  31. $globals.Silk);
  32. $core.addMethod(
  33. $core.method({
  34. selector: "newElement:xmlns:",
  35. protocol: "writing",
  36. //>>excludeStart("ide", pragmas.excludeIdeData);
  37. args: ["aString", "anotherString"],
  38. source: "newElement: aString xmlns: anotherString\x0a\x09| el |\x0a\x09\x0a\x09el := self class newElement: aString xmlns: anotherString.\x0a\x09self << el.\x0a\x09^ el",
  39. referencedClasses: [],
  40. //>>excludeEnd("ide");
  41. pragmas: [],
  42. messageSends: ["newElement:xmlns:", "class", "<<"]
  43. }, function ($methodClass){ return function (aString,anotherString){
  44. var self=this,$self=this;
  45. var el;
  46. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  47. return $core.withContext(function($ctx1) {
  48. //>>excludeEnd("ctx");
  49. el=$recv($self._class())._newElement_xmlns_(aString,anotherString);
  50. $self.__lt_lt(el);
  51. return el;
  52. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  53. }, function($ctx1) {$ctx1.fill(self,"newElement:xmlns:",{aString:aString,anotherString:anotherString,el:el})});
  54. //>>excludeEnd("ctx");
  55. }; }),
  56. $globals.Silk);
  57. $core.addMethod(
  58. $core.method({
  59. selector: "nextPut:",
  60. protocol: "writing",
  61. //>>excludeStart("ide", pragmas.excludeIdeData);
  62. args: ["anObject"],
  63. source: "nextPut: anObject\x0a\x09\x22Double-dispatches anObject via renderOnSilk: message.\x0a\x09If a message returns nil, this fallbacks to superclass.\x0a\x09Otherwise, it is assumed renderOnSilk: did its job.\x22\x0a\x0a\x09(anObject renderOnSilk: self)\x0a\x09\x09ifNil: [ super nextPut: anObject ]",
  64. referencedClasses: [],
  65. //>>excludeEnd("ide");
  66. pragmas: [],
  67. messageSends: ["ifNil:", "renderOnSilk:", "nextPut:"]
  68. }, function ($methodClass){ return function (anObject){
  69. var self=this,$self=this;
  70. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  71. return $core.withContext(function($ctx1) {
  72. //>>excludeEnd("ctx");
  73. var $1;
  74. $1=$recv(anObject)._renderOnSilk_(self);
  75. if($1 == null || $1.a$nil){
  76. [(
  77. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  78. $ctx1.supercall = true,
  79. //>>excludeEnd("ctx");
  80. ($methodClass.superclass||$boot.nilAsClass).fn.prototype._nextPut_.call($self,anObject))
  81. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  82. ,$ctx1.supercall = false
  83. //>>excludeEnd("ctx");
  84. ][0];
  85. } else {
  86. $1;
  87. }
  88. return self;
  89. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  90. }, function($ctx1) {$ctx1.fill(self,"nextPut:",{anObject:anObject})});
  91. //>>excludeEnd("ctx");
  92. }; }),
  93. $globals.Silk);
  94. $core.addMethod(
  95. $core.method({
  96. selector: "htmlNamespace",
  97. protocol: "accessing",
  98. //>>excludeStart("ide", pragmas.excludeIdeData);
  99. args: [],
  100. source: "htmlNamespace\x0a\x09\x22<String>\x0a\x09XML namespace for HTML elements.\x0a\x09The default for all virtual Silk tag messages\x22\x0a\x09\x0a\x09^ 'http://www.w3.org/1999/xhtml'",
  101. referencedClasses: [],
  102. //>>excludeEnd("ide");
  103. pragmas: [],
  104. messageSends: []
  105. }, function ($methodClass){ return function (){
  106. var self=this,$self=this;
  107. return "http://www.w3.org/1999/xhtml";
  108. }; }),
  109. $globals.Silk.a$cls);
  110. $core.addMethod(
  111. $core.method({
  112. selector: "namespace",
  113. protocol: "accessing",
  114. //>>excludeStart("ide", pragmas.excludeIdeData);
  115. args: [],
  116. source: "namespace\x0a\x09\x22<String>\x0a\x09XML namespace for elements: html.\x0a\x09The default for all virtual Silk tag messages\x22\x0a\x09\x0a\x09^ self htmlNamespace",
  117. referencedClasses: [],
  118. //>>excludeEnd("ide");
  119. pragmas: [],
  120. messageSends: ["htmlNamespace"]
  121. }, function ($methodClass){ return function (){
  122. var self=this,$self=this;
  123. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  124. return $core.withContext(function($ctx1) {
  125. //>>excludeEnd("ctx");
  126. return $self._htmlNamespace();
  127. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  128. }, function($ctx1) {$ctx1.fill(self,"namespace",{})});
  129. //>>excludeEnd("ctx");
  130. }; }),
  131. $globals.Silk.a$cls);
  132. $core.addTrait("TSilkBuilder", "Silk");
  133. //>>excludeStart("ide", pragmas.excludeIdeData);
  134. $globals.TSilkBuilder.comment="I contain Silk's \x22build element via DNU\x22 behaviour.\x0a\x0aI expect #namespace and #newElement:xmlns: to be implemented.";
  135. //>>excludeEnd("ide");
  136. $core.addMethod(
  137. $core.method({
  138. selector: "doesNotUnderstand:",
  139. protocol: "message handling",
  140. //>>excludeStart("ide", pragmas.excludeIdeData);
  141. args: ["aMessage"],
  142. source: "doesNotUnderstand: aMessage\x0a\x09\x22`self DIV` creates (and optionally inserts) a div element.\x0a\x09`aSilk DIV: anObject` creates (and optionally inserts)\x0a\x09a div element, and puts contents in it\x22\x0a\x09^ (self tryMakeDnuElement: aMessage)\x0a\x09\x09ifNil: [ super doesNotUnderstand: aMessage ]",
  143. referencedClasses: [],
  144. //>>excludeEnd("ide");
  145. pragmas: [],
  146. messageSends: ["ifNil:", "tryMakeDnuElement:", "doesNotUnderstand:"]
  147. }, function ($methodClass){ return function (aMessage){
  148. var self=this,$self=this;
  149. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  150. return $core.withContext(function($ctx1) {
  151. //>>excludeEnd("ctx");
  152. var $1;
  153. $1=$self._tryMakeDnuElement_(aMessage);
  154. if($1 == null || $1.a$nil){
  155. return [(
  156. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  157. $ctx1.supercall = true,
  158. //>>excludeEnd("ctx");
  159. ($methodClass.superclass||$boot.nilAsClass).fn.prototype._doesNotUnderstand_.call($self,aMessage))
  160. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  161. ,$ctx1.supercall = false
  162. //>>excludeEnd("ctx");
  163. ][0];
  164. } else {
  165. return $1;
  166. }
  167. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  168. }, function($ctx1) {$ctx1.fill(self,"doesNotUnderstand:",{aMessage:aMessage})});
  169. //>>excludeEnd("ctx");
  170. }; }),
  171. $globals.TSilkBuilder);
  172. $core.addMethod(
  173. $core.method({
  174. selector: "newSvgElement",
  175. protocol: "convenience",
  176. //>>excludeStart("ide", pragmas.excludeIdeData);
  177. args: [],
  178. source: "newSvgElement\x0a\x09^ self newElement: 'svg' xmlns: 'http://www.w3.org/2000/svg'",
  179. referencedClasses: [],
  180. //>>excludeEnd("ide");
  181. pragmas: [],
  182. messageSends: ["newElement:xmlns:"]
  183. }, function ($methodClass){ return function (){
  184. var self=this,$self=this;
  185. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  186. return $core.withContext(function($ctx1) {
  187. //>>excludeEnd("ctx");
  188. return $self._newElement_xmlns_("svg","http://www.w3.org/2000/svg");
  189. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  190. }, function($ctx1) {$ctx1.fill(self,"newSvgElement",{})});
  191. //>>excludeEnd("ctx");
  192. }; }),
  193. $globals.TSilkBuilder);
  194. $core.addMethod(
  195. $core.method({
  196. selector: "tryMakeDnuElement:",
  197. protocol: "instance creation",
  198. //>>excludeStart("ide", pragmas.excludeIdeData);
  199. args: ["aMessage"],
  200. source: "tryMakeDnuElement: aMessage\x0a\x09\x22`DIV` creates a div element.\x0a\x09`DIV: anObject` creates a div element and puts contents in it.\x0a\x09An element can be optionally inserted by #newElement:xmlns:.\x0a\x09When self is an instance and not the class Silk, \x0a\x09then the instance's namespace is used for the new element.\x0a\x09You can do:\x0a\x09\x09svg := Silk newElement: 'svg' xmlns: 'http://www.w3.org/2000/svg'.\x0a\x09\x09svg CIRCLE: {'cx' -> 60. 'cy' -> 25. 'r' -> 10}.\x0a\x09This creates a svg circle, not a html circle.\x22\x0a\x09\x0a\x09| selector newElement useArg |\x0a\x09selector := aMessage selector.\x0a\x09selector asUppercase = selector\x0a\x09\x09ifFalse: [ ^ nil ].\x0a\x09selector last = ':'\x0a\x09\x09ifTrue: [ useArg := true. selector := selector allButLast ]\x0a\x09\x09ifFalse: [ useArg := false ].\x0a\x09(selector includes: ':')\x0a\x09\x09ifTrue: [ ^ nil ].\x0a\x09newElement := self newElement: selector asLowercase xmlns: self namespace.\x0a\x09useArg ifTrue: [ newElement << aMessage arguments first ].\x0a\x09^ newElement",
  201. referencedClasses: [],
  202. //>>excludeEnd("ide");
  203. pragmas: [],
  204. messageSends: ["selector", "ifFalse:", "=", "asUppercase", "ifTrue:ifFalse:", "last", "allButLast", "ifTrue:", "includes:", "newElement:xmlns:", "asLowercase", "namespace", "<<", "first", "arguments"]
  205. }, function ($methodClass){ return function (aMessage){
  206. var self=this,$self=this;
  207. var selector,newElement,useArg;
  208. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  209. return $core.withContext(function($ctx1) {
  210. //>>excludeEnd("ctx");
  211. selector=$recv(aMessage)._selector();
  212. if(!$core.assert([$recv($recv(selector)._asUppercase()).__eq(selector)
  213. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  214. ,$ctx1.sendIdx["="]=1
  215. //>>excludeEnd("ctx");
  216. ][0])){
  217. return nil;
  218. }
  219. if($core.assert($recv($recv(selector)._last()).__eq(":"))){
  220. useArg=true;
  221. selector=$recv(selector)._allButLast();
  222. selector;
  223. } else {
  224. useArg=false;
  225. useArg;
  226. }
  227. if($core.assert($recv(selector)._includes_(":"))){
  228. return nil;
  229. }
  230. newElement=$self._newElement_xmlns_($recv(selector)._asLowercase(),$self._namespace());
  231. if($core.assert(useArg)){
  232. $recv(newElement).__lt_lt($recv($recv(aMessage)._arguments())._first());
  233. }
  234. return newElement;
  235. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  236. }, function($ctx1) {$ctx1.fill(self,"tryMakeDnuElement:",{aMessage:aMessage,selector:selector,newElement:newElement,useArg:useArg})});
  237. //>>excludeEnd("ctx");
  238. }; }),
  239. $globals.TSilkBuilder);
  240. $core.setTraitComposition([{trait: $globals.TSilkBuilder}], $globals.Silk);
  241. $core.setTraitComposition([{trait: $globals.TSilkBuilder}], $globals.Silk.a$cls);
  242. $core.addMethod(
  243. $core.method({
  244. selector: "renderOnSilk:",
  245. protocol: "*Silk",
  246. //>>excludeStart("ide", pragmas.excludeIdeData);
  247. args: ["aSilk"],
  248. source: "renderOnSilk: aSilk\x0a\x09key attrPut: value on: aSilk",
  249. referencedClasses: [],
  250. //>>excludeEnd("ide");
  251. pragmas: [],
  252. messageSends: ["attrPut:on:"]
  253. }, function ($methodClass){ return function (aSilk){
  254. var self=this,$self=this;
  255. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  256. return $core.withContext(function($ctx1) {
  257. //>>excludeEnd("ctx");
  258. $recv($self.key)._attrPut_on_($self.value,aSilk);
  259. return self;
  260. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  261. }, function($ctx1) {$ctx1.fill(self,"renderOnSilk:",{aSilk:aSilk})});
  262. //>>excludeEnd("ctx");
  263. }; }),
  264. $globals.Association);
  265. $core.addMethod(
  266. $core.method({
  267. selector: "renderOnSilk:",
  268. protocol: "*Silk",
  269. //>>excludeStart("ide", pragmas.excludeIdeData);
  270. args: ["aSilk"],
  271. source: "renderOnSilk: aSilk\x0a\x09self value: aSilk",
  272. referencedClasses: [],
  273. //>>excludeEnd("ide");
  274. pragmas: [],
  275. messageSends: ["value:"]
  276. }, function ($methodClass){ return function (aSilk){
  277. var self=this,$self=this;
  278. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  279. return $core.withContext(function($ctx1) {
  280. //>>excludeEnd("ctx");
  281. $self._value_(aSilk);
  282. return self;
  283. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  284. }, function($ctx1) {$ctx1.fill(self,"renderOnSilk:",{aSilk:aSilk})});
  285. //>>excludeEnd("ctx");
  286. }; }),
  287. $globals.BlockClosure);
  288. $core.addMethod(
  289. $core.method({
  290. selector: "inSilk",
  291. protocol: "*Silk",
  292. //>>excludeStart("ide", pragmas.excludeIdeData);
  293. args: [],
  294. source: "inSilk\x0a\x09^ Silk newStream << self; yourself",
  295. referencedClasses: ["Silk"],
  296. //>>excludeEnd("ide");
  297. pragmas: [],
  298. messageSends: ["<<", "newStream", "yourself"]
  299. }, function ($methodClass){ return function (){
  300. var self=this,$self=this;
  301. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  302. return $core.withContext(function($ctx1) {
  303. //>>excludeEnd("ctx");
  304. var $1;
  305. $1=$recv($globals.Silk)._newStream();
  306. $recv($1).__lt_lt(self);
  307. return $recv($1)._yourself();
  308. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  309. }, function($ctx1) {$ctx1.fill(self,"inSilk",{})});
  310. //>>excludeEnd("ctx");
  311. }; }),
  312. $globals.JSObjectProxy);
  313. $core.addMethod(
  314. $core.method({
  315. selector: "renderOnSilk:",
  316. protocol: "*Silk",
  317. //>>excludeStart("ide", pragmas.excludeIdeData);
  318. args: ["aSilk"],
  319. source: "renderOnSilk: aSilk\x0a\x09^ nil",
  320. referencedClasses: [],
  321. //>>excludeEnd("ide");
  322. pragmas: [],
  323. messageSends: []
  324. }, function ($methodClass){ return function (aSilk){
  325. var self=this,$self=this;
  326. return nil;
  327. }; }),
  328. $globals.JSObjectProxy);
  329. $core.addMethod(
  330. $core.method({
  331. selector: "inSilk",
  332. protocol: "*Silk",
  333. //>>excludeStart("ide", pragmas.excludeIdeData);
  334. args: [],
  335. source: "inSilk\x0a\x09^ Silk newStream << self; yourself",
  336. referencedClasses: ["Silk"],
  337. //>>excludeEnd("ide");
  338. pragmas: [],
  339. messageSends: ["<<", "newStream", "yourself"]
  340. }, function ($methodClass){ return function (){
  341. var self=this,$self=this;
  342. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  343. return $core.withContext(function($ctx1) {
  344. //>>excludeEnd("ctx");
  345. var $1;
  346. $1=$recv($globals.Silk)._newStream();
  347. $recv($1).__lt_lt(self);
  348. return $recv($1)._yourself();
  349. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  350. }, function($ctx1) {$ctx1.fill(self,"inSilk",{})});
  351. //>>excludeEnd("ctx");
  352. }; }),
  353. $globals.Object);
  354. $core.addMethod(
  355. $core.method({
  356. selector: "renderOnSilk:",
  357. protocol: "*Silk",
  358. //>>excludeStart("ide", pragmas.excludeIdeData);
  359. args: ["aSilk"],
  360. source: "renderOnSilk: aSilk\x0a\x09^ nil",
  361. referencedClasses: [],
  362. //>>excludeEnd("ide");
  363. pragmas: [],
  364. messageSends: []
  365. }, function ($methodClass){ return function (aSilk){
  366. var self=this,$self=this;
  367. return nil;
  368. }; }),
  369. $globals.Object);
  370. $core.addMethod(
  371. $core.method({
  372. selector: "asSilk",
  373. protocol: "*Silk",
  374. //>>excludeStart("ide", pragmas.excludeIdeData);
  375. args: [],
  376. source: "asSilk\x0a\x09^ Silk at: self asString",
  377. referencedClasses: ["Silk"],
  378. //>>excludeEnd("ide");
  379. pragmas: [],
  380. messageSends: ["at:", "asString"]
  381. }, function ($methodClass){ return function (){
  382. var self=this,$self=this;
  383. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  384. return $core.withContext(function($ctx1) {
  385. //>>excludeEnd("ctx");
  386. return $recv($globals.Silk)._at_($self._asString());
  387. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  388. }, function($ctx1) {$ctx1.fill(self,"asSilk",{})});
  389. //>>excludeEnd("ctx");
  390. }; }),
  391. $globals.String);
  392. $core.addMethod(
  393. $core.method({
  394. selector: "attrPut:on:",
  395. protocol: "*Silk",
  396. //>>excludeStart("ide", pragmas.excludeIdeData);
  397. args: ["anObject", "aSilk"],
  398. source: "attrPut: anObject on: aSilk\x0a\x09aSilk attrAt: self put: anObject",
  399. referencedClasses: [],
  400. //>>excludeEnd("ide");
  401. pragmas: [],
  402. messageSends: ["attrAt:put:"]
  403. }, function ($methodClass){ return function (anObject,aSilk){
  404. var self=this,$self=this;
  405. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  406. return $core.withContext(function($ctx1) {
  407. //>>excludeEnd("ctx");
  408. $recv(aSilk)._attrAt_put_(self,anObject);
  409. return self;
  410. //>>excludeStart("ctx", pragmas.excludeDebugContexts);
  411. }, function($ctx1) {$ctx1.fill(self,"attrPut:on:",{anObject:anObject,aSilk:aSilk})});
  412. //>>excludeEnd("ctx");
  413. }; }),
  414. $globals.String);
  415. });