Documentation.deploy.js 50 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939
  1. smalltalk.addPackage('Documentation', {});
  2. smalltalk.addClass('DocumentationBuilder', smalltalk.Object, ['chapters', 'announcer', 'widget'], 'Documentation');
  3. smalltalk.addMethod(
  4. '_chapters',
  5. smalltalk.method({
  6. selector: 'chapters',
  7. fn: function (){
  8. var self=this;
  9. return (($receiver = self['@chapters']) == nil || $receiver == undefined) ? (function(){return (self['@chapters']=smalltalk.send(self, "_buildChapters", []));})() : $receiver;
  10. return self;}
  11. }),
  12. smalltalk.DocumentationBuilder);
  13. smalltalk.addMethod(
  14. '_announcer',
  15. smalltalk.method({
  16. selector: 'announcer',
  17. fn: function (){
  18. var self=this;
  19. return (($receiver = self['@announcer']) == nil || $receiver == undefined) ? (function(){return (self['@announcer']=smalltalk.send((smalltalk.Announcer || Announcer), "_new", []));})() : $receiver;
  20. return self;}
  21. }),
  22. smalltalk.DocumentationBuilder);
  23. smalltalk.addMethod(
  24. '_widget',
  25. smalltalk.method({
  26. selector: 'widget',
  27. fn: function (){
  28. var self=this;
  29. return (($receiver = self['@widget']) == nil || $receiver == undefined) ? (function(){return (self['@widget']=smalltalk.send((smalltalk.DocumentationWidget || DocumentationWidget), "_on_", [self]));})() : $receiver;
  30. return self;}
  31. }),
  32. smalltalk.DocumentationBuilder);
  33. smalltalk.addMethod(
  34. '_buildChapters',
  35. smalltalk.method({
  36. selector: 'buildChapters',
  37. fn: function (){
  38. var self=this;
  39. return smalltalk.send(smalltalk.send(smalltalk.send(smalltalk.send(smalltalk.send(smalltalk.send(self, "_class", []), "_methodDictionary", []), "_values", []), "_sorted_", [(function(a, b){return ((($receiver = smalltalk.send(a, "_selector", [])).klass === smalltalk.Number) ? $receiver <smalltalk.send(b, "_selector", []) : smalltalk.send($receiver, "__lt", [smalltalk.send(b, "_selector", [])]));})]), "_select_", [(function(each){return smalltalk.send(smalltalk.send(each, "_category", []), "__eq", ["chapters"]);})]), "_collect_", [(function(each){return smalltalk.send(self, "_perform_", [smalltalk.send(each, "_selector", [])]);})]);
  40. return self;}
  41. }),
  42. smalltalk.DocumentationBuilder);
  43. smalltalk.addMethod(
  44. '_buildOn_',
  45. smalltalk.method({
  46. selector: 'buildOn:',
  47. fn: function (aCanvas){
  48. var self=this;
  49. smalltalk.send(aCanvas, "_with_", [smalltalk.send(self, "_widget", [])]);
  50. (function($rec){smalltalk.send($rec, "_checkHashChange", []);return smalltalk.send($rec, "_checkHash", []);})(self);
  51. return self;}
  52. }),
  53. smalltalk.DocumentationBuilder);
  54. smalltalk.addMethod(
  55. '_buildOnJQuery_',
  56. smalltalk.method({
  57. selector: 'buildOnJQuery:',
  58. fn: function (aJQuery){
  59. var self=this;
  60. smalltalk.send(self, "_buildOn_", [smalltalk.send((smalltalk.HTMLCanvas || HTMLCanvas), "_onJQuery_", [aJQuery])]);
  61. return self;}
  62. }),
  63. smalltalk.DocumentationBuilder);
  64. smalltalk.addMethod(
  65. '_build',
  66. smalltalk.method({
  67. selector: 'build',
  68. fn: function (){
  69. var self=this;
  70. smalltalk.send(self, "_buildOnJQuery_", [smalltalk.send("body", "_asJQuery", [])]);
  71. return self;}
  72. }),
  73. smalltalk.DocumentationBuilder);
  74. smalltalk.addMethod(
  75. '_ch1introduction',
  76. smalltalk.method({
  77. selector: 'ch1introduction',
  78. fn: function (){
  79. var self=this;
  80. return (function($rec){smalltalk.send($rec, "_title_", ["Introduction"]);return smalltalk.send($rec, "_contents_", [unescape("%0A%0A%23%23Amber%20Smalltalk%20in%20a%20nutshell%0A%0AAmber%20is%20an%20implementation%20of%20the%20Smalltalk-80%20language.%20It%20is%20designed%20to%20make%20client-side%20web%20development%20**faster%2C%20easier%20and%20more%20fun**%20as%20it%20allows%20developers%20to%20write%20HTML5%20applications%20in%20a%20live%20Smalltalk%20environment%21%0A%0AAmber%20is%20written%20in%20itself%2C%20including%20the%20IDE%20and%20the%20compiler%20and%20it%20runs%20**directly%20inside%20your%20browser**.%20The%20IDE%20is%20fairly%20complete%20with%20a%20class%20browser%2C%20workspace%2C%20transcript%2C%20unit%20test%20runner%2C%20object%20inspectors%2C%20cross%20reference%20tools%20and%20even%20a%20debugger.%0A%0ANoteworthy%20features%3A%0A%0A-%20Amber%20is%20semantically%20and%20syntactically%20very%20close%20to%20%5BPharo%20Smalltalk%5D%28http%3A//www.pharo-project.org%29.%20Pharo%20is%20considered%20the%20reference%20implementation.%0A-%20Amber%20**seamlessly%20interacts%20with%20JavaScript**%20and%20can%20use%20its%20full%20eco%20system%20of%20libraries%20without%20any%20glue%20code%20needed.%0A-%20Amber%20**has%20no%20dependencies**%20and%20can%20be%20used%20in%20any%20JavaScript%20runtime%2C%20not%20only%20inside%20browsers.%20An%20important%20example%20is%20%5BNode.js%5D%28http%3A//nodejs.org%29.%0A-%20Amber%20is%20a%20live%20Smalltalk%20that%20**compiles%20incrementally%20into%20efficient%20JavaScript**%20often%20mapping%20one-to-one%20with%20JavaScript%20equivalents.%0A-%20Amber%20has%20a%20**Seaside%20influenced%20canvas%20library**%20to%20dynamically%20generate%20HTML.%0A%0A%23%23%20Arguments%20for%20using%20Amber%0AIn%20our%20humble%20opinion%20the%20main%20arguments%20for%20using%20Amber%20are%3A%0A%0A-%20JavaScript%20is%20quite%20a%20broken%20language%20with%20lots%20of%20traps%20and%20odd%20quirks.%20It%20is%20the%20assembler%20of%20the%20Internet%20which%20is%20cool%2C%20but%20we%20don%27t%20want%20to%20write%20in%20it.%0A-%20Smalltalk%20as%20a%20language%20is%20immensely%20cleaner%20and%20more%20mature%2C%20both%20syntactically%20and%20semantically.%0A-%20Smalltalk%20has%20a%20simple%20class%20model%20with%20a%20lightweight%20syntax%20for%20closures%2C%20it%20is%20in%20many%20ways%20a%20perfect%20match%20for%20the%20Good%20Parts%20of%20JavaScript.%0A-%20Having%20a%20true%20live%20interactive%20incremental%20development%20environment%20where%20you%20can%20build%20your%20application%20directly%20in%20the%20browser%20is%20unbeatable.%0A%0A%23%23%20Disclaimer%0A%0AThis%20documentation%20doesn%27t%20aim%20to%20teach%20Smalltalk.%20%0AKnowledge%20of%20Smalltalk%20is%20needed%20to%20understand%20the%20topics%20covered%20in%20this%20documentation.%20%0AIf%20you%20want%20to%20learn%20the%20Smalltalk%20language%2C%20you%20can%20read%20the%20excellent%20%5BPharo%20By%20Example%5D%28http%3A//www.pharobyexample.org%29%20book.%0A")]);})(smalltalk.send((smalltalk.DocChapter || DocChapter), "_new", []));
  81. return self;}
  82. }),
  83. smalltalk.DocumentationBuilder);
  84. smalltalk.addMethod(
  85. '_ch2differencesWithOtherSmalltalks',
  86. smalltalk.method({
  87. selector: 'ch2differencesWithOtherSmalltalks',
  88. fn: function (){
  89. var self=this;
  90. return (function($rec){smalltalk.send($rec, "_title_", ["Differences with other Smalltalks"]);return smalltalk.send($rec, "_contents_", [unescape("%0AAmber%20has%20some%20differences%20with%20other%20Smalltalk%20implementations.%20This%20makes%20porting%20code%20a%20non-trivial%20thing%2C%20but%20still%20quite%20manageable.%0ABecause%20it%20maps%20Smalltalk%20constructs%20one-to-one%20with%20the%20JavaScript%20equivalent%2C%20including%20Smalltalk%20classes%20to%20JavaScript%20constructors%2C%20the%20core%20class%20library%20is%20simplified%20compared%20to%20Pharo%20Smalltalk.%0AAnd%20since%20we%20want%20Amber%20to%20be%20useful%20in%20building%20lean%20browser%20apps%20we%20can%27t%20let%20it%20bloat%20too%20much.%0A%0ABut%20apart%20from%20missing%20things%20other%20Smalltalks%20may%20have%2C%20there%20are%20also%20things%20that%20are%20plain%20different%3A%0A%0A-%20The%20collection%20class%20hierarchy%20is%20much%20simpler%20compared%20to%20most%20Smalltalk%20implementations.%0A-%20As%20of%20today%2C%20there%20is%20no%20SortedCollection.%20The%20size%20of%20arrays%20is%20dynamic%2C%20and%20they%20behave%20like%20an%20ordered%20collection.%20They%20can%20also%20be%20sorted%20with%20the%20%60%23sort*%60%20methods.%0A-%20The%20%60Date%60%20class%20behaves%20like%20the%20%60Date%60%20and%20%60TimeStamp%60%20classes%20in%20Pharo%20Smalltalk.%20Therefore%20both%20%60Date%20today%60%20and%20%60Date%20now%60%20are%20valid%20in%20Amber.%0A-%20Amber%20does%20not%20have%20class%20Character%2C%20but%20%60String%60%20does%20implement%20some%20of%20Character%20behavior.%0A-%20Amber%20does%20support%20class%20instance%20variables%2C%20but%20not%20class%20variables.%0A-%20Amber%20only%20has%20global%20classes%20and%20packages%2C%20but%20not%20arbitrary%20objects.%20Use%20classes%20instead%20like%20%60Smalltalk%20current%60%20instead%20of%20%60Smalltalk%60%20etc.%0A-%20Amber%20does%20not%20support%20pool%20dictionaries.%0A-%20Amber%20uses%20**%3C%20...javascript%20code...%20%3E**%20to%20inline%20JavaScript%20code%20and%20does%20not%20have%20pragmas.%0A-%20Amber%20does%20not%20have%20class%20categories.%20The%20left%20side%20in%20the%20browser%20lists%20real%20Packages%2C%20but%20they%20feel%20much%20the%20same.%0A")]);})(smalltalk.send((smalltalk.DocChapter || DocChapter), "_new", []));
  91. return self;}
  92. }),
  93. smalltalk.DocumentationBuilder);
  94. smalltalk.addMethod(
  95. '_ch3GettingStarted',
  96. smalltalk.method({
  97. selector: 'ch3GettingStarted',
  98. fn: function (){
  99. var self=this;
  100. return (function($rec){smalltalk.send($rec, "_title_", ["Getting started"]);return smalltalk.send($rec, "_contents_", [unescape("%0ATo%20get%20started%20hacking%20in%20Amber%20you%20can%20basically%20take%20three%20routes%2C%20independent%20of%20your%20platform%3A%0A%0A1.%20Just%20try%20it%20out%20at%20http%3A//www.amber-lang.net%20%28click%20the%20%22Class%20browser%22%20button%29%20-%20but%20you%20will%20**not%20be%20able%20to%20save%20any%20code%20you%20write**%21%20%0A%20%20%20%20Still%2C%20it%20works%20fine%20for%20looking%20at%20the%20IDE%20and%20playing%20around.%20Just%20don%27t%20press%20F5/reload%20-%20it%20will%20bring%20you%20back%20to%20zero.%20%0A%20%20%20%20%28Well%2C%20if%20you%20still%20want%20to%20develop%20and%20save%20code%20online%20someone%20has%20set%20up%20this%20site%20seems%20for%20free%20use%3A%20https%3A//www.screwtopdb.com/amberstore/topics%3Fname%3Damberstore/amber.html%20%29%0A2.%20Download%20an%20Amber%20zip-ball%2C%20install%20Nodejs%2C%20fire%20up%20the%20Amber%20server%20and%20then%20open%20Amber%20from%20localhost%20-%20then%20you%20**can%20save%20code**.%20Detailed%20instructions%20are%20below%21%0A3.%20Same%20as%20above%20but%20install%20git%20first%20and%20get%20a%20proper%20clone%20from%20http%3A//github.com/NicolasPetton/amber%20instead%20of%20a%20zip/tar-ball.%20%0A%20%20%20%20If%20you%20want%20to%20**contribute%20to%20Amber%20itself**%20this%20is%20really%20what%20you%20want%20to%20do.%20It%20requires%20installing%20git%20first%2C%20but%20it%20is%20quite%20simple%20-%20although%20we%20leave%20this%20bit%20as%20an%20%22exercise%20to%20the%20reader%22%20%3A%29%0A%0A**PLEASE%20NOTE%3A**%20Amber%20core%20developers%20use%20Linux.%20%0AWe%20do%20not%20want%20to%20introduce%20dependencies%20that%20aren%27t%20cross%20platform%20-%20but%20currently%20amberc%20%28the%20command%20line%20compiler%29%20is%20a%20bash%20script%20and%20we%20also%20use%20Makefiles%20%0A%28for%20building%20Amber%20itself%20and%20server%20side%20examples%29%20written%20on%20Linux/Unix.%20So%20using%20Windows%20is%20currently%20a%20bit%20limited%20-%20you%20can%27t%20run%20%22make%22%20in%20the%20.st%20directory%20to%20rebuild%20whole%20of%20Amber%20for%20example.%0A%20BUT...%20if%20you%20only%20want%20to%20use%20Amber%20to%20build%20web%20client%20apps%20and%20not%20really%20get%20involved%20in%20hacking%20Amber%20itself%20-%20then%20you%20should%20be%20fine%21%0A%0A%23%23%20Downloading%20Amber%0ACurrently%20you%20can%20download%20in%20zip%20or%20tar-ball%20format%2C%20either%20cutting%20edge%20or%20a%20release.%20%5BDownloads%20are%20available%20here%5D%28https%3A//github.com/NicolasPetton/amber/archives/amber%29.%20%0AAt%20the%20moment%20of%20writing%20you%20have%20release%20%5B0.9%20as%20zip%5D%28https%3A//github.com/NicolasPetton/amber/zipball/0.9%29%20or%20%5Btar%5D%28https%3A//github.com/NicolasPetton/amber/tarball/0.9%29%2C%20%0Aor%20%5Bcutting%20edge%20as%20zip%5D%28https%3A//github.com/NicolasPetton/amber/zipball/amber%29%20or%20%5Btar%5D%28https%3A//github.com/NicolasPetton/amber/tarball/amber%29.%0A%0AAt%20the%20moment%20this%20is%20just%20a%20**1.5Mb%20download**%2C%20so%20its%20very%20small.%20Unpack%20wherever%20you%20like%2C%20but%20I%20would%20rename%20the%20directory%20that%20is%20unpacked%20to%20something%20slightly%20shorter%20-%20like%20say%20%22amber-0.9%22%20or%20just%20%22amber%22.%20%0AAnd%20yes%2C%20at%20this%20point%20you%20can%20double%20click%20the%20index.html%20file%20in%20the%20amber%20directory%20to%20get%20the%20IDE%20up%2C%20but%20again%2C%20**you%20will%20not%20be%20able%20to%20save%20code**.%20So%20please%20continue%20below%20%3A%29%0A%0A%23%23%20Installing%20Node.js%0A%5BNode%5D%28http%3A//www.nodejs.org%29%20%28for%20short%29%20is%20simply%20the%20V8%20Javascript%20VM%20from%20Google%20%28used%20in%20Chrome%29%20hooked%20together%20with%20some%20hard%20core%20C-libraries%20for%20doing%20%22evented%20I/O%22.%0A%20Basically%20it%27s%20Javascript%20for%20the%20server%20-%20on%20asynch%20steroids.%20Amber%20runs%20fine%20in%20Node%20and%20we%20use%20it%20for%20several%20Amber%20tools%2C%20like%20amberc%20%28the%20command%20line%20Amber%20compiler%29%20or%20the%20Amber%20server%20%28see%20below%29.%20%0AThere%20are%20also%20several%20Amber-Node%20example%20to%20look%20at%20if%20you%20want%20to%20play%20with%20running%20Amber%20programs%20server%20side.%20**In%20short%20-%20you%20really%20want%20to%20install%20Nodejs.%20%3A%29**%0A%0A-%20Installing%20Node%20on%20Linux%20can%20be%20done%20using%20your%20package%20tool%20of%20choice%20%28%22apt-get%20install%20nodejs%22%20for%20example%29%20or%20any%20other%20way%20described%20at%20%5Bthe%20download%20page%5D%28http%3A//nodejs.org/%23download%29.%0A-%20Installing%20Node%20on%20MacOS%20seems%20to%20be%20easiest%20by%20getting%20it%20from%20%5Bhere%5D%28https%3A//sites.google.com/site/nodejsmacosx/%29.%0A-%20Installing%20Node%20on%20Windows%20is%20probably%20done%20best%20by%20using%20the%20%5Bdownload%20from%20Nodejs.org%5D%28http%3A//nodejs.org/%23download%29.%20This%20is%20not%20an%20installer%2C%20it%20is%20instead%20simply%20the%20node%20executable%20-%20**node.exe**.%0A%20%20%20%20-%20Put%20node.exe%20somewhere%20in%20your%20path.%20In%20Windows7%20I%20can%20run%20a%20command%20prompt%20%22As%20administrator%22%20%28right%20click%20the%20command%20prompt%20in%20Start%20menu%29%20and%20then%20just%20%22copy%20node.exe%20c%3A%5Cwindows%5C%22%20or%20such.%0A%0A%23%23%20Starting%20Amber%20server%0ANicolas%20has%20written%20a%20minimal%20webDAV%20server%20that%20is%20the%20easiest%20way%20to%20get%20up%20and%20running%20Amber%20with%20the%20ability%20to%20save%20code.%20This%20little%20server%20is%20written%20in...%20Amber%21%20%0AAnd%20it%20runs%20on%20top%20of%20Node.%20So%20to%20start%20it%20up%20serving%20your%20brand%20new%20directory%20tree%20of%20sweet%20Amber%20you%20do%3A%0A%0A%20%20%20%20cd%20amber%20%20%20%20%20%20%28or%20whatever%20you%20called%20the%20directory%20you%20unpackaged%29%0A%20%20%20%20./bin/server%20%20%28in%20windows%20you%20type%20%22node%20server%5Cserver.js%22%20instead%29%0A%0AIt%20should%20say%20it%20is%20listening%20on%20port%204000.%20If%20it%20does%2C%20hooray%21%20That%20means%20both%20Node%20and%20Amber%20are%20good.%20In%20Windows%20you%20might%20get%20a%20question%20about%20opening%20that%20port%20in%20the%20local%20firewall%20-%20yep%2C%20do%20it%21%0A%0A%23%23%20Firing%20up%20Amber%0AThe%20Amber%20IDE%20is%20written%20in...%20Amber.%20It%20uses%20JQuery%20and%20runs%20right%20in%20your%20browser%20as%20a%20...%20well%2C%20a%20web%20page.%20%0AWe%20could%20open%20it%20up%20just%20using%20a%20file%20url%20-%20but%20the%20reason%20we%20performed%20the%20previous%20steps%20is%20so%20that%20we%20can%20load%20the%20IDE%20web%20page%20from%20a%20server%20that%20can%20handle%20PUTs%20%28webDAV%29%20of%20source%20code.%20%0AAccording%20to%20web%20security%20Amber%20can%20only%20do%20PUT%20back%20to%20the%20same%20server%20it%20was%20loaded%20from.%20Thus%20we%20instead%20want%20to%20open%20it%20through%20our%20little%20server%20now%20listening%20on%20port%204000%3A%0A%0A%20%20%20%20http%3A//localhost%3A4000/index.html%0A%0AClicking%20the%20above%20link%20should%20get%20your%20Amber%20running.%0A%0ATo%20verify%20that%20you%20can%20indeed%20commit%20-%20just%20select%20a%20Package%20in%20the%20browser%2C%20like%20say%20%22Examples%22%20and%20press%20%22Commit%20package%22%20button.%20**If%20all%20goes%20well%20nothing%20happens%20%3A%29**.%20%0ASo%20in%20order%20to%20really%20know%20if%20it%20worked%20we%20can%20check%20the%20modified%20date%20on%20the%20files%20**amber/st/Examples.st**%2C%20**amber/js/Examples.js**%20and%20**amber/js/Examples.deploy.js**%20-%20they%20should%20be%20brand%20new.%0A%0ANOTE%3A%20We%20can%20use%20any%20webDAV%20server%20and%20Apache2%20has%20been%20used%20earlier%20and%20works%20fine.%20But%20the%20Amber%20server%20is%20smaller%20and%20simpler%20to%20start.%0A%0A")]);})(smalltalk.send((smalltalk.DocChapter || DocChapter), "_new", []));
  101. return self;}
  102. }),
  103. smalltalk.DocumentationBuilder);
  104. smalltalk.addMethod(
  105. '_ch5Index',
  106. smalltalk.method({
  107. selector: 'ch5Index',
  108. fn: function (){
  109. var self=this;
  110. return smalltalk.send((smalltalk.ClassesIndexChapter || ClassesIndexChapter), "_new", []);
  111. return self;}
  112. }),
  113. smalltalk.DocumentationBuilder);
  114. smalltalk.addMethod(
  115. '_ch6KernelObjects',
  116. smalltalk.method({
  117. selector: 'ch6KernelObjects',
  118. fn: function (){
  119. var self=this;
  120. return smalltalk.send((smalltalk.PackageDocChapter || PackageDocChapter), "_on_", [smalltalk.send((smalltalk.Package || Package), "_named_", [unescape("Kernel-Objects")])]);
  121. return self;}
  122. }),
  123. smalltalk.DocumentationBuilder);
  124. smalltalk.addMethod(
  125. '_ch7KernelClasses',
  126. smalltalk.method({
  127. selector: 'ch7KernelClasses',
  128. fn: function (){
  129. var self=this;
  130. return smalltalk.send((smalltalk.PackageDocChapter || PackageDocChapter), "_on_", [smalltalk.send((smalltalk.Package || Package), "_named_", [unescape("Kernel-Classes")])]);
  131. return self;}
  132. }),
  133. smalltalk.DocumentationBuilder);
  134. smalltalk.addMethod(
  135. '_ch4Tutorials',
  136. smalltalk.method({
  137. selector: 'ch4Tutorials',
  138. fn: function (){
  139. var self=this;
  140. return smalltalk.send((smalltalk.TutorialsChapter || TutorialsChapter), "_new", []);
  141. return self;}
  142. }),
  143. smalltalk.DocumentationBuilder);
  144. smalltalk.addMethod(
  145. '_checkHashChange',
  146. smalltalk.method({
  147. selector: 'checkHashChange',
  148. fn: function (){
  149. var self=this;
  150. smalltalk.send(smalltalk.send((typeof window == 'undefined' ? nil : window), "_jQuery_", [(typeof window == 'undefined' ? nil : window)]), "_bind_do_", ["hashchange", (function(){return smalltalk.send(self, "_checkHash", []);})]);
  151. return self;}
  152. }),
  153. smalltalk.DocumentationBuilder);
  154. smalltalk.addMethod(
  155. '_checkHash',
  156. smalltalk.method({
  157. selector: 'checkHash',
  158. fn: function (){
  159. var self=this;
  160. var hash=nil;
  161. var presentation=nil;
  162. (hash=smalltalk.send(smalltalk.send(smalltalk.send((typeof document == 'undefined' ? nil : document), "_location", []), "_hash", []), "_replace_with_", [unescape("%5E%23"), ""]));
  163. smalltalk.send(smalltalk.send(self, "_announcer", []), "_announce_", [(function($rec){smalltalk.send($rec, "_id_", [hash]);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send((smalltalk.ChapterSelectionAnnouncement || ChapterSelectionAnnouncement), "_new", []))]);
  164. return self;}
  165. }),
  166. smalltalk.DocumentationBuilder);
  167. smalltalk.addMethod(
  168. '_update',
  169. smalltalk.method({
  170. selector: 'update',
  171. fn: function (){
  172. var self=this;
  173. (self['@chapters']=nil);
  174. (self['@announcer']=nil);
  175. (self['@widget']=nil);
  176. smalltalk.send(smalltalk.send((typeof window == 'undefined' ? nil : window), "_jQuery_", [".documentation"]), "_remove", []);
  177. smalltalk.send(self, "_build", []);
  178. return self;}
  179. }),
  180. smalltalk.DocumentationBuilder);
  181. smalltalk.DocumentationBuilder.klass.iVarNames = ['current'];
  182. smalltalk.addMethod(
  183. '_current',
  184. smalltalk.method({
  185. selector: 'current',
  186. fn: function (){
  187. var self=this;
  188. return (($receiver = self['@current']) == nil || $receiver == undefined) ? (function(){return (self['@current']=smalltalk.send(self, "_new", []));})() : $receiver;
  189. return self;}
  190. }),
  191. smalltalk.DocumentationBuilder.klass);
  192. smalltalk.addMethod(
  193. '_initialize',
  194. smalltalk.method({
  195. selector: 'initialize',
  196. fn: function (){
  197. var self=this;
  198. smalltalk.send(smalltalk.send(self, "_current", []), "_build", []);
  199. return self;}
  200. }),
  201. smalltalk.DocumentationBuilder.klass);
  202. smalltalk.addClass('DocChapter', smalltalk.Widget, ['title', 'contents', 'parent'], 'Documentation');
  203. smalltalk.addMethod(
  204. '_title',
  205. smalltalk.method({
  206. selector: 'title',
  207. fn: function (){
  208. var self=this;
  209. return (($receiver = self['@title']) == nil || $receiver == undefined) ? (function(){return "";})() : $receiver;
  210. return self;}
  211. }),
  212. smalltalk.DocChapter);
  213. smalltalk.addMethod(
  214. '_title_',
  215. smalltalk.method({
  216. selector: 'title:',
  217. fn: function (aString){
  218. var self=this;
  219. (self['@title']=aString);
  220. return self;}
  221. }),
  222. smalltalk.DocChapter);
  223. smalltalk.addMethod(
  224. '_contents',
  225. smalltalk.method({
  226. selector: 'contents',
  227. fn: function (){
  228. var self=this;
  229. return (($receiver = self['@contents']) == nil || $receiver == undefined) ? (function(){return "";})() : $receiver;
  230. return self;}
  231. }),
  232. smalltalk.DocChapter);
  233. smalltalk.addMethod(
  234. '_contents_',
  235. smalltalk.method({
  236. selector: 'contents:',
  237. fn: function (aString){
  238. var self=this;
  239. (self['@contents']=aString);
  240. return self;}
  241. }),
  242. smalltalk.DocChapter);
  243. smalltalk.addMethod(
  244. '_htmlContents',
  245. smalltalk.method({
  246. selector: 'htmlContents',
  247. fn: function (){
  248. var self=this;
  249. return smalltalk.send(smalltalk.send(smalltalk.send((smalltalk.Showdown || Showdown), "_at_", [smalltalk.symbolFor("converter")]), "_new", []), "_makeHtml_", [smalltalk.send(self, "_contents", [])]);
  250. return self;}
  251. }),
  252. smalltalk.DocChapter);
  253. smalltalk.addMethod(
  254. '_chapters',
  255. smalltalk.method({
  256. selector: 'chapters',
  257. fn: function (){
  258. var self=this;
  259. return [];
  260. return self;}
  261. }),
  262. smalltalk.DocChapter);
  263. smalltalk.addMethod(
  264. '_cssClass',
  265. smalltalk.method({
  266. selector: 'cssClass',
  267. fn: function (){
  268. var self=this;
  269. return "doc_chapter";
  270. return self;}
  271. }),
  272. smalltalk.DocChapter);
  273. smalltalk.addMethod(
  274. '_level',
  275. smalltalk.method({
  276. selector: 'level',
  277. fn: function (){
  278. var self=this;
  279. return (($receiver = smalltalk.send(self, "_parent", [])) == nil || $receiver == undefined) ? (function(){return (1);})() : (function(){return ((($receiver = smalltalk.send(smalltalk.send(self, "_parent", []), "_level", [])).klass === smalltalk.Number) ? $receiver +(1) : smalltalk.send($receiver, "__plus", [(1)]));})();
  280. return self;}
  281. }),
  282. smalltalk.DocChapter);
  283. smalltalk.addMethod(
  284. '_level_',
  285. smalltalk.method({
  286. selector: 'level:',
  287. fn: function (anInteger){
  288. var self=this;
  289. (level=anInteger);
  290. return self;}
  291. }),
  292. smalltalk.DocChapter);
  293. smalltalk.addMethod(
  294. '_parent',
  295. smalltalk.method({
  296. selector: 'parent',
  297. fn: function (){
  298. var self=this;
  299. return self['@parent'];
  300. return self;}
  301. }),
  302. smalltalk.DocChapter);
  303. smalltalk.addMethod(
  304. '_parent_',
  305. smalltalk.method({
  306. selector: 'parent:',
  307. fn: function (aChapter){
  308. var self=this;
  309. (self['@parent']=aChapter);
  310. return self;}
  311. }),
  312. smalltalk.DocChapter);
  313. smalltalk.addMethod(
  314. '_id',
  315. smalltalk.method({
  316. selector: 'id',
  317. fn: function (){
  318. var self=this;
  319. return smalltalk.send(smalltalk.send(self, "_title", []), "_replace_with_", [" ", unescape("-")]);
  320. return self;}
  321. }),
  322. smalltalk.DocChapter);
  323. smalltalk.addMethod(
  324. '_announcer',
  325. smalltalk.method({
  326. selector: 'announcer',
  327. fn: function (){
  328. var self=this;
  329. return smalltalk.send(smalltalk.send((smalltalk.DocumentationBuilder || DocumentationBuilder), "_current", []), "_announcer", []);
  330. return self;}
  331. }),
  332. smalltalk.DocChapter);
  333. smalltalk.addMethod(
  334. '_selectClass_',
  335. smalltalk.method({
  336. selector: 'selectClass:',
  337. fn: function (aClass){
  338. var self=this;
  339. smalltalk.send(smalltalk.send(smalltalk.send((smalltalk.DocumentationBuilder || DocumentationBuilder), "_current", []), "_announcer", []), "_announce_", [smalltalk.send((smalltalk.ClassSelectionAnnouncement || ClassSelectionAnnouncement), "_on_", [aClass])]);
  340. return self;}
  341. }),
  342. smalltalk.DocChapter);
  343. smalltalk.addMethod(
  344. '_selectChapter_',
  345. smalltalk.method({
  346. selector: 'selectChapter:',
  347. fn: function (aChapter){
  348. var self=this;
  349. smalltalk.send(smalltalk.send((typeof document == 'undefined' ? nil : document), "_location", []), "_hash_", [smalltalk.send(aChapter, "_id", [])]);
  350. return self;}
  351. }),
  352. smalltalk.DocChapter);
  353. smalltalk.addMethod(
  354. '_displayChapter_',
  355. smalltalk.method({
  356. selector: 'displayChapter:',
  357. fn: function (aChapter){
  358. var self=this;
  359. smalltalk.send(smalltalk.send(smalltalk.send((smalltalk.DocumentationBuilder || DocumentationBuilder), "_current", []), "_widget", []), "_displayChapter_", [aChapter]);
  360. return self;}
  361. }),
  362. smalltalk.DocChapter);
  363. smalltalk.addMethod(
  364. '_initialize',
  365. smalltalk.method({
  366. selector: 'initialize',
  367. fn: function (){
  368. var self=this;
  369. smalltalk.send(self, "_initialize", [], smalltalk.Widget);
  370. smalltalk.send(self, "_subscribe", []);
  371. return self;}
  372. }),
  373. smalltalk.DocChapter);
  374. smalltalk.addMethod(
  375. '_renderOn_',
  376. smalltalk.method({
  377. selector: 'renderOn:',
  378. fn: function (html){
  379. var self=this;
  380. (function($rec){smalltalk.send($rec, "_class_", [smalltalk.send(self, "_cssClass", [])]);return smalltalk.send($rec, "_with_", [(function(){smalltalk.send(self, "_renderDocOn_", [html]);return smalltalk.send(self, "_renderLinksOn_", [html]);})]);})(smalltalk.send(html, "_div", []));
  381. return self;}
  382. }),
  383. smalltalk.DocChapter);
  384. smalltalk.addMethod(
  385. '_renderDocOn_',
  386. smalltalk.method({
  387. selector: 'renderDocOn:',
  388. fn: function (html){
  389. var self=this;
  390. var div=nil;
  391. smalltalk.send(smalltalk.send(html, "_h1", []), "_with_", [smalltalk.send(self, "_title", [])]);
  392. smalltalk.send(self, "_renderNavigationOn_", [html]);
  393. (div=smalltalk.send(smalltalk.send(html, "_div", []), "_class_", ["contents"]));
  394. smalltalk.send(smalltalk.send(div, "_asJQuery", []), "_html_", [smalltalk.send(self, "_htmlContents", [])]);
  395. return self;}
  396. }),
  397. smalltalk.DocChapter);
  398. smalltalk.addMethod(
  399. '_renderNavigationOn_',
  400. smalltalk.method({
  401. selector: 'renderNavigationOn:',
  402. fn: function (html){
  403. var self=this;
  404. (($receiver = smalltalk.send(self, "_parent", [])) != nil && $receiver != undefined) ? (function(){return (function($rec){smalltalk.send($rec, "_class_", ["navigation"]);return smalltalk.send($rec, "_with_", [(function(){return (function($rec){smalltalk.send($rec, "_with_", [smalltalk.send(unescape("%u2190%20back%20to%20"), "__comma", [smalltalk.send(smalltalk.send(self, "_parent", []), "_title", [])])]);return smalltalk.send($rec, "_onClick_", [(function(){return smalltalk.send(self, "_selectChapter_", [smalltalk.send(self, "_parent", [])]);})]);})(smalltalk.send(html, "_a", []));})]);})(smalltalk.send(html, "_div", []));})() : nil;
  405. return self;}
  406. }),
  407. smalltalk.DocChapter);
  408. smalltalk.addMethod(
  409. '_renderLinksOn_',
  410. smalltalk.method({
  411. selector: 'renderLinksOn:',
  412. fn: function (html){
  413. var self=this;
  414. (function($rec){smalltalk.send($rec, "_class_", ["links"]);return smalltalk.send($rec, "_with_", [(function(){return smalltalk.send(smalltalk.send(self, "_chapters", []), "_do_", [(function(each){return smalltalk.send(smalltalk.send(html, "_li", []), "_with_", [(function(){return (function($rec){smalltalk.send($rec, "_with_", [smalltalk.send(each, "_title", [])]);return smalltalk.send($rec, "_onClick_", [(function(){return smalltalk.send(self, "_selectChapter_", [each]);})]);})(smalltalk.send(html, "_a", []));})]);})]);})]);})(smalltalk.send(html, "_ul", []));
  415. return self;}
  416. }),
  417. smalltalk.DocChapter);
  418. smalltalk.addMethod(
  419. '_subscribe',
  420. smalltalk.method({
  421. selector: 'subscribe',
  422. fn: function (){
  423. var self=this;
  424. smalltalk.send(smalltalk.send(self, "_announcer", []), "_on_do_", [(smalltalk.ChapterSelectionAnnouncement || ChapterSelectionAnnouncement), (function(ann){return ((($receiver = smalltalk.send(smalltalk.send(ann, "_id", []), "__eq", [smalltalk.send(self, "_id", [])])).klass === smalltalk.Boolean) ? ($receiver ? (function(){return smalltalk.send(self, "_displayChapter_", [self]);})() : nil) : smalltalk.send($receiver, "_ifTrue_", [(function(){return smalltalk.send(self, "_displayChapter_", [self]);})]));})]);
  425. return self;}
  426. }),
  427. smalltalk.DocChapter);
  428. smalltalk.addClass('PackageDocChapter', smalltalk.DocChapter, ['package', 'chapters'], 'Documentation');
  429. smalltalk.addMethod(
  430. '_package',
  431. smalltalk.method({
  432. selector: 'package',
  433. fn: function (){
  434. var self=this;
  435. return self['@package'];
  436. return self;}
  437. }),
  438. smalltalk.PackageDocChapter);
  439. smalltalk.addMethod(
  440. '_title',
  441. smalltalk.method({
  442. selector: 'title',
  443. fn: function (){
  444. var self=this;
  445. return smalltalk.send("Package ", "__comma", [smalltalk.send(smalltalk.send(self, "_package", []), "_name", [])]);
  446. return self;}
  447. }),
  448. smalltalk.PackageDocChapter);
  449. smalltalk.addMethod(
  450. '_chapters',
  451. smalltalk.method({
  452. selector: 'chapters',
  453. fn: function (){
  454. var self=this;
  455. return self['@chapters'];
  456. return self;}
  457. }),
  458. smalltalk.PackageDocChapter);
  459. smalltalk.addMethod(
  460. '_contents',
  461. smalltalk.method({
  462. selector: 'contents',
  463. fn: function (){
  464. var self=this;
  465. return smalltalk.send(smalltalk.send("Classes in package ", "__comma", [smalltalk.send(smalltalk.send(self, "_package", []), "_name", [])]), "__comma", [":"]);
  466. return self;}
  467. }),
  468. smalltalk.PackageDocChapter);
  469. smalltalk.addMethod(
  470. '_initializeWithPackage_',
  471. smalltalk.method({
  472. selector: 'initializeWithPackage:',
  473. fn: function (aPackage){
  474. var self=this;
  475. (self['@package']=aPackage);
  476. (self['@chapters']=smalltalk.send(smalltalk.send(smalltalk.send(aPackage, "_classes", []), "_sorted_", [(function(a, b){return ((($receiver = smalltalk.send(a, "_name", [])).klass === smalltalk.Number) ? $receiver <smalltalk.send(b, "_name", []) : smalltalk.send($receiver, "__lt", [smalltalk.send(b, "_name", [])]));})]), "_collect_", [(function(each){return (function($rec){smalltalk.send($rec, "_parent_", [self]);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send((smalltalk.ClassDocChapter || ClassDocChapter), "_on_", [each]));})]));
  477. return self;}
  478. }),
  479. smalltalk.PackageDocChapter);
  480. smalltalk.addMethod(
  481. '_on_',
  482. smalltalk.method({
  483. selector: 'on:',
  484. fn: function (aPackage){
  485. var self=this;
  486. return (function($rec){smalltalk.send($rec, "_initializeWithPackage_", [aPackage]);smalltalk.send($rec, "_initialize", []);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send(self, "_basicNew", []));
  487. return self;}
  488. }),
  489. smalltalk.PackageDocChapter.klass);
  490. smalltalk.addClass('ClassDocChapter', smalltalk.DocChapter, ['theClass'], 'Documentation');
  491. smalltalk.addMethod(
  492. '_theClass',
  493. smalltalk.method({
  494. selector: 'theClass',
  495. fn: function (){
  496. var self=this;
  497. return self['@theClass'];
  498. return self;}
  499. }),
  500. smalltalk.ClassDocChapter);
  501. smalltalk.addMethod(
  502. '_contents',
  503. smalltalk.method({
  504. selector: 'contents',
  505. fn: function (){
  506. var self=this;
  507. return ((($receiver = smalltalk.send(smalltalk.send(smalltalk.send(self, "_theClass", []), "_comment", []), "_isEmpty", [])).klass === smalltalk.Boolean) ? ($receiver ? (function(){return smalltalk.send(smalltalk.send(smalltalk.send(self, "_theClass", []), "_name", []), "__comma", [" is not documented yet."]);})() : (function(){return smalltalk.send(smalltalk.send(self, "_theClass", []), "_comment", []);})()) : smalltalk.send($receiver, "_ifTrue_ifFalse_", [(function(){return smalltalk.send(smalltalk.send(smalltalk.send(self, "_theClass", []), "_name", []), "__comma", [" is not documented yet."]);}), (function(){return smalltalk.send(smalltalk.send(self, "_theClass", []), "_comment", []);})]));
  508. return self;}
  509. }),
  510. smalltalk.ClassDocChapter);
  511. smalltalk.addMethod(
  512. '_cssClass',
  513. smalltalk.method({
  514. selector: 'cssClass',
  515. fn: function (){
  516. var self=this;
  517. return smalltalk.send("doc_class ", "__comma", [smalltalk.send(self, "_cssClass", [], smalltalk.DocChapter)]);
  518. return self;}
  519. }),
  520. smalltalk.ClassDocChapter);
  521. smalltalk.addMethod(
  522. '_title',
  523. smalltalk.method({
  524. selector: 'title',
  525. fn: function (){
  526. var self=this;
  527. return smalltalk.send(smalltalk.send(self, "_theClass", []), "_name", []);
  528. return self;}
  529. }),
  530. smalltalk.ClassDocChapter);
  531. smalltalk.addMethod(
  532. '_initializeWithClass_',
  533. smalltalk.method({
  534. selector: 'initializeWithClass:',
  535. fn: function (aClass){
  536. var self=this;
  537. (self['@theClass']=aClass);
  538. return self;}
  539. }),
  540. smalltalk.ClassDocChapter);
  541. smalltalk.addMethod(
  542. '_renderLinksOn_',
  543. smalltalk.method({
  544. selector: 'renderLinksOn:',
  545. fn: function (html){
  546. var self=this;
  547. (function($rec){smalltalk.send($rec, "_class_", ["links"]);return smalltalk.send($rec, "_with_", [(function(){return smalltalk.send(smalltalk.send(html, "_li", []), "_with_", [(function(){return (function($rec){smalltalk.send($rec, "_with_", ["Browse this class"]);return smalltalk.send($rec, "_onClick_", [(function(){return smalltalk.send((smalltalk.Browser || Browser), "_openOn_", [smalltalk.send(self, "_theClass", [])]);})]);})(smalltalk.send(html, "_a", []));})]);})]);})(smalltalk.send(html, "_ul", []));
  548. return self;}
  549. }),
  550. smalltalk.ClassDocChapter);
  551. smalltalk.addMethod(
  552. '_subscribe',
  553. smalltalk.method({
  554. selector: 'subscribe',
  555. fn: function (){
  556. var self=this;
  557. smalltalk.send(self, "_subscribe", [], smalltalk.DocChapter);
  558. smalltalk.send(smalltalk.send(self, "_announcer", []), "_on_do_", [(smalltalk.ClassSelectionAnnouncement || ClassSelectionAnnouncement), (function(ann){return ((($receiver = smalltalk.send(smalltalk.send(ann, "_theClass", []), "__eq", [smalltalk.send(self, "_theClass", [])])).klass === smalltalk.Boolean) ? ($receiver ? (function(){return smalltalk.send(self, "_selectChapter_", [self]);})() : nil) : smalltalk.send($receiver, "_ifTrue_", [(function(){return smalltalk.send(self, "_selectChapter_", [self]);})]));})]);
  559. return self;}
  560. }),
  561. smalltalk.ClassDocChapter);
  562. smalltalk.addMethod(
  563. '_on_',
  564. smalltalk.method({
  565. selector: 'on:',
  566. fn: function (aClass){
  567. var self=this;
  568. return (function($rec){smalltalk.send($rec, "_initializeWithClass_", [aClass]);smalltalk.send($rec, "_initialize", []);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send(self, "_basicNew", []));
  569. return self;}
  570. }),
  571. smalltalk.ClassDocChapter.klass);
  572. smalltalk.addClass('DocumentationWidget', smalltalk.Widget, ['builder', 'selectedChapter', 'chapterDiv'], 'Documentation');
  573. smalltalk.addMethod(
  574. '_builder',
  575. smalltalk.method({
  576. selector: 'builder',
  577. fn: function (){
  578. var self=this;
  579. return self['@builder'];
  580. return self;}
  581. }),
  582. smalltalk.DocumentationWidget);
  583. smalltalk.addMethod(
  584. '_builder_',
  585. smalltalk.method({
  586. selector: 'builder:',
  587. fn: function (aDocumentationBuilder){
  588. var self=this;
  589. (self['@builder']=aDocumentationBuilder);
  590. return self;}
  591. }),
  592. smalltalk.DocumentationWidget);
  593. smalltalk.addMethod(
  594. '_chapters',
  595. smalltalk.method({
  596. selector: 'chapters',
  597. fn: function (){
  598. var self=this;
  599. return smalltalk.send(smalltalk.send(self, "_builder", []), "_chapters", []);
  600. return self;}
  601. }),
  602. smalltalk.DocumentationWidget);
  603. smalltalk.addMethod(
  604. '_selectedChapter',
  605. smalltalk.method({
  606. selector: 'selectedChapter',
  607. fn: function (){
  608. var self=this;
  609. return (($receiver = self['@selectedChapter']) == nil || $receiver == undefined) ? (function(){return (self['@selectedChapter']=smalltalk.send(smalltalk.send(self, "_chapters", []), "_first", []));})() : $receiver;
  610. return self;}
  611. }),
  612. smalltalk.DocumentationWidget);
  613. smalltalk.addMethod(
  614. '_selectedChapter_',
  615. smalltalk.method({
  616. selector: 'selectedChapter:',
  617. fn: function (aChapter){
  618. var self=this;
  619. return (self['@selectedChapter']=aChapter);
  620. return self;}
  621. }),
  622. smalltalk.DocumentationWidget);
  623. smalltalk.addMethod(
  624. '_displayChapter_',
  625. smalltalk.method({
  626. selector: 'displayChapter:',
  627. fn: function (aChapter){
  628. var self=this;
  629. smalltalk.send(self, "_selectedChapter_", [aChapter]);
  630. smalltalk.send(self, "_updateChapterDiv", []);
  631. return self;}
  632. }),
  633. smalltalk.DocumentationWidget);
  634. smalltalk.addMethod(
  635. '_selectChapter_',
  636. smalltalk.method({
  637. selector: 'selectChapter:',
  638. fn: function (aChapter){
  639. var self=this;
  640. smalltalk.send(smalltalk.send((typeof document == 'undefined' ? nil : document), "_location", []), "_hash_", [smalltalk.send(aChapter, "_id", [])]);
  641. return self;}
  642. }),
  643. smalltalk.DocumentationWidget);
  644. smalltalk.addMethod(
  645. '_renderOn_',
  646. smalltalk.method({
  647. selector: 'renderOn:',
  648. fn: function (html){
  649. var self=this;
  650. (function($rec){smalltalk.send($rec, "_class_", ["documentation"]);return smalltalk.send($rec, "_with_", [(function(){smalltalk.send(self, "_renderMenuOn_", [html]);(self['@chapterDiv']=smalltalk.send(html, "_div", []));return smalltalk.send(self, "_updateChapterDiv", []);})]);})(smalltalk.send(html, "_div", []));
  651. return self;}
  652. }),
  653. smalltalk.DocumentationWidget);
  654. smalltalk.addMethod(
  655. '_renderMenuOn_',
  656. smalltalk.method({
  657. selector: 'renderMenuOn:',
  658. fn: function (html){
  659. var self=this;
  660. (function($rec){smalltalk.send($rec, "_class_", ["menu"]);return smalltalk.send($rec, "_with_", [(function(){return smalltalk.send(smalltalk.send(html, "_ol", []), "_with_", [(function(){return smalltalk.send(smalltalk.send(self, "_chapters", []), "_do_", [(function(each){return smalltalk.send(smalltalk.send(html, "_li", []), "_with_", [(function(){return smalltalk.send(self, "_renderChapterMenu_on_", [each, html]);})]);})]);})]);})]);})(smalltalk.send(html, "_div", []));
  661. return self;}
  662. }),
  663. smalltalk.DocumentationWidget);
  664. smalltalk.addMethod(
  665. '_renderChapterMenu_on_',
  666. smalltalk.method({
  667. selector: 'renderChapterMenu:on:',
  668. fn: function (aChapter, html){
  669. var self=this;
  670. (function($rec){smalltalk.send($rec, "_with_", [smalltalk.send(aChapter, "_title", [])]);return smalltalk.send($rec, "_onClick_", [(function(){return smalltalk.send(self, "_selectChapter_", [aChapter]);})]);})(smalltalk.send(html, "_a", []));
  671. smalltalk.send(smalltalk.send(html, "_ol", []), "_with_", [(function(){return smalltalk.send(smalltalk.send(aChapter, "_chapters", []), "_do_", [(function(each){return smalltalk.send(smalltalk.send(html, "_li", []), "_with_", [(function(){return smalltalk.send(self, "_renderChapterMenu_on_", [each, html]);})]);})]);})]);
  672. return self;}
  673. }),
  674. smalltalk.DocumentationWidget);
  675. smalltalk.addMethod(
  676. '_updateChapterDiv',
  677. smalltalk.method({
  678. selector: 'updateChapterDiv',
  679. fn: function (){
  680. var self=this;
  681. smalltalk.send(self['@chapterDiv'], "_contents_", [(function(html){return smalltalk.send(html, "_with_", [smalltalk.send(self, "_selectedChapter", [])]);})]);
  682. return self;}
  683. }),
  684. smalltalk.DocumentationWidget);
  685. smalltalk.addMethod(
  686. '_on_',
  687. smalltalk.method({
  688. selector: 'on:',
  689. fn: function (aBuilder){
  690. var self=this;
  691. return (function($rec){smalltalk.send($rec, "_builder_", [aBuilder]);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send(self, "_new", []));
  692. return self;}
  693. }),
  694. smalltalk.DocumentationWidget.klass);
  695. smalltalk.addClass('ClassesIndexChapter', smalltalk.DocChapter, [], 'Documentation');
  696. smalltalk.addMethod(
  697. '_cssClass',
  698. smalltalk.method({
  699. selector: 'cssClass',
  700. fn: function (){
  701. var self=this;
  702. return smalltalk.send("index_doc ", "__comma", [smalltalk.send(self, "_cssClass", [], smalltalk.DocChapter)]);
  703. return self;}
  704. }),
  705. smalltalk.ClassesIndexChapter);
  706. smalltalk.addMethod(
  707. '_title',
  708. smalltalk.method({
  709. selector: 'title',
  710. fn: function (){
  711. var self=this;
  712. return "Smalltalk classes by index";
  713. return self;}
  714. }),
  715. smalltalk.ClassesIndexChapter);
  716. smalltalk.addMethod(
  717. '_alphabet',
  718. smalltalk.method({
  719. selector: 'alphabet',
  720. fn: function (){
  721. var self=this;
  722. return "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
  723. return self;}
  724. }),
  725. smalltalk.ClassesIndexChapter);
  726. smalltalk.addMethod(
  727. '_renderDocOn_',
  728. smalltalk.method({
  729. selector: 'renderDocOn:',
  730. fn: function (html){
  731. var self=this;
  732. smalltalk.send(smalltalk.send(html, "_h1", []), "_with_", [smalltalk.send(self, "_title", [])]);
  733. smalltalk.send(smalltalk.send(self, "_alphabet", []), "_do_", [(function(letter){var classes=nil;
  734. (classes=smalltalk.send(smalltalk.send(smalltalk.send((smalltalk.Smalltalk || Smalltalk), "_current", []), "_classes", []), "_select_", [(function(each){return smalltalk.send(smalltalk.send(smalltalk.send(each, "_name", []), "_first", []), "__eq", [letter]);})]));smalltalk.send(classes, "_ifNotEmpty_", [(function(){return smalltalk.send(smalltalk.send(html, "_h2", []), "_with_", [letter]);})]);return smalltalk.send(smalltalk.send(html, "_ul", []), "_with_", [(function(){return smalltalk.send(smalltalk.send(classes, "_sorted_", [(function(a, b){return ((($receiver = smalltalk.send(a, "_name", [])).klass === smalltalk.Number) ? $receiver <smalltalk.send(b, "_name", []) : smalltalk.send($receiver, "__lt", [smalltalk.send(b, "_name", [])]));})]), "_do_", [(function(each){return smalltalk.send(smalltalk.send(html, "_li", []), "_with_", [(function(){return (function($rec){smalltalk.send($rec, "_with_", [smalltalk.send(each, "_name", [])]);return smalltalk.send($rec, "_onClick_", [(function(){return smalltalk.send(self, "_selectClass_", [each]);})]);})(smalltalk.send(html, "_a", []));})]);})]);})]);})]);
  735. return self;}
  736. }),
  737. smalltalk.ClassesIndexChapter);
  738. smalltalk.addClass('ClassSelectionAnnouncement', smalltalk.Object, ['theClass'], 'Documentation');
  739. smalltalk.addMethod(
  740. '_theClass',
  741. smalltalk.method({
  742. selector: 'theClass',
  743. fn: function (){
  744. var self=this;
  745. return self['@theClass'];
  746. return self;}
  747. }),
  748. smalltalk.ClassSelectionAnnouncement);
  749. smalltalk.addMethod(
  750. '_theClass_',
  751. smalltalk.method({
  752. selector: 'theClass:',
  753. fn: function (aClass){
  754. var self=this;
  755. (self['@theClass']=aClass);
  756. return self;}
  757. }),
  758. smalltalk.ClassSelectionAnnouncement);
  759. smalltalk.addMethod(
  760. '_on_',
  761. smalltalk.method({
  762. selector: 'on:',
  763. fn: function (aClass){
  764. var self=this;
  765. return (function($rec){smalltalk.send($rec, "_theClass_", [aClass]);return smalltalk.send($rec, "_yourself", []);})(smalltalk.send(self, "_new", []));
  766. return self;}
  767. }),
  768. smalltalk.ClassSelectionAnnouncement.klass);
  769. smalltalk.addClass('ChapterSelectionAnnouncement', smalltalk.Object, ['id'], 'Documentation');
  770. smalltalk.addMethod(
  771. '_id',
  772. smalltalk.method({
  773. selector: 'id',
  774. fn: function (){
  775. var self=this;
  776. return self['@id'];
  777. return self;}
  778. }),
  779. smalltalk.ChapterSelectionAnnouncement);
  780. smalltalk.addMethod(
  781. '_id_',
  782. smalltalk.method({
  783. selector: 'id:',
  784. fn: function (aString){
  785. var self=this;
  786. (self['@id']=aString);
  787. return self;}
  788. }),
  789. smalltalk.ChapterSelectionAnnouncement);
  790. smalltalk.addClass('TutorialsChapter', smalltalk.DocChapter, [], 'Documentation');
  791. smalltalk.addMethod(
  792. '_title',
  793. smalltalk.method({
  794. selector: 'title',
  795. fn: function (){
  796. var self=this;
  797. return "Tutorials";
  798. return self;}
  799. }),
  800. smalltalk.TutorialsChapter);
  801. smalltalk.addMethod(
  802. '_contents',
  803. smalltalk.method({
  804. selector: 'contents',
  805. fn: function (){
  806. var self=this;
  807. return unescape("Here%27s%20a%20serie%20of%20tutorials.%20If%20you%20are%20new%20to%20Smalltalk%2C%20you%20can%20also%20learn%20Amber%20online%20with%20%5BProfStef%5D%28http%3A//www.amber-lang.net/learn.html%29");
  808. return self;}
  809. }),
  810. smalltalk.TutorialsChapter);
  811. smalltalk.addMethod(
  812. '_chapters',
  813. smalltalk.method({
  814. selector: 'chapters',
  815. fn: function (){
  816. var self=this;
  817. return [smalltalk.send(self, "_firstAppChapter", []),smalltalk.send(self, "_counterChapter", [])];
  818. return self;}
  819. }),
  820. smalltalk.TutorialsChapter);
  821. smalltalk.addMethod(
  822. '_firstAppChapter',
  823. smalltalk.method({
  824. selector: 'firstAppChapter',
  825. fn: function (){
  826. var self=this;
  827. return (function($rec){smalltalk.send($rec, "_title_", ["A first application"]);return smalltalk.send($rec, "_contents_", [unescape("%0A%0ALet%27s%20make%20Hello%20World%20in%20Amber.%0A%0AFirst%2C%20you%20need%20a%20place%20for%20your%20new%20project.%20I%20made%20a%20new%20directory%20under%20amber%3A%0A%0A%20%20%20%20amber/projects/hello%0A%0AThis%20will%20store%20your%20project%20files.%20To%20get%20started%2C%20add%20a%20new%20index.html%20file%20to%20this%20folder%2C%20as%20well%20as%20empty%20js%20and%20st%20folders.%0A%0AYour%20index.html%20can%20be%20really%20basic.%20The%20most%20important%20thing%20it%20does%20is%20include%20amber.js%20and%20run%20loadAmber.%20Here%20is%20a%20basic%20index.html%20you%20can%20use%3A%0A%0A%0A%20%20%20%20%3C%21DOCTYPE%20html%3E%0A%20%20%20%20%3Chtml%3E%0A%20%20%20%20%20%20%3Chead%3E%0A%20%20%20%20%20%20%20%20%3Ctitle%3EMy%20First%20Amber%20Project%3C/title%3E%0A%20%20%20%20%20%20%20%20%3Cscript%20src%3D%22../../js/amber.js%22%20type%3D%22text/javascript%22%3E%3C/script%3E%0A%20%20%20%20%20%20%20%20%3Cscript%20type%3D%22text/javascript%22%3E%0A%20%20%20%20%20%20%20%20%20%20loadAmber%28%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20files%3A%20%5B%5D%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20prefix%3A%20%27projects/hello/js%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20ready%3A%20function%28%29%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%7D%29%3B%20%0A%20%20%20%20%20%20%20%20%3C/script%3E%0A%20%20%20%20%20%20%3C/head%3E%0A%20%20%20%20%20%20%3Cbody%3E%0A%20%20%20%20%20%20%20%20%3Carticle%3E%0A%20%20%20%20%20%20%20%20%20%20%3Ch1%3EMy%20First%20Amber%20Project%3C/h1%3E%0A%20%20%20%20%20%20%20%20%20%20%3Cbutton%20onclick%3D%22smalltalk.Browser._open%28%29%22%3Eclass%20browser%3C/button%3E%0A%20%20%20%20%20%20%20%20%20%20%3Cbutton%20id%3D%22sayHello%22%3Esay%20hello%3C/button%3E%0A%20%20%20%20%20%20%20%20%3C/article%3E%0A%20%20%20%20%20%20%3C/body%3E%0A%20%20%20%20%3C/html%3E%0A%0ANow%20start%20up%20amber%20with%20node.js%20and%20navigate%20to%20%20http%3A//localhost%3A4000/projects/hello/index.html%0A%0AIt%27s%20boring%20so%20far%2C%20so%20lets%20write%20some%20code.%20Click%20the%20button%20to%20open%20the%20class%20browser.%20Find%20an%20existing%20class%20and%20change%20its%20name%20to%20Hello%20and%20its%20package%20to%20HelloApp.%20%0AThen%20click%20save.%20This%20creates%20a%20new%20class%20and%20leaves%20the%20old%20one%20intact%2C%20it%20doesn%27t%20overwrite%20it.%20Your%20class%20will%20look%20like%20this%3A%0A%0A%20%20%20%20Object%20subclass%3A%20%23Hello%0A%20%20%20%20%20%20%20%20instanceVariableNames%3A%20%27%27%0A%20%20%20%20%20%20%20%20package%3A%20%27HelloApp%27%0A%0ANow%20click%20save%20and%20navigate%20to%20your%20new%20class%20in%20its%20new%20package.%0A%20Then%20click%20%27commit%20package%27.%20You%20just%20created%20a%20new%20class%20and%20saved%20your%20work.%20%0AOn%20your%20file%20system%20check%20out%20your%20js%20and%20st%20folders.%20Your%20new%20class%20is%20now%20saved%20in%20both%20JavaScript%20and%20Smalltalk.%0A%0ANow%2C%20refresh%20your%20browser%20page%20and%20reopen%20the%20class%20browser.%20Oh%20no%2C%20your%20new%20class%20is%20gone%21%20To%20load%20your%20new%20class%20automatically%2C%20you%20have%20to%20add%20it%20in%20index.html.%20Make%20your%20JavaScript%20look%20like%20this%3A%0A%0A%0A%20%20%20%20loadAmber%28%7B%0A%20%20%20%20%20%20%20%20files%3A%20%5B%27HelloApp.js%27%5D%2C%0A%20%20%20%20%20%20%20%20prefix%3A%20%27projects/hello/js%27%2C%0A%20%20%20%20%20%20%20%20ready%3A%20function%28%29%20%7B%20%20%20%20%20%20%0A%20%20%20%20%7D%7D%29%3B%20%0A%0ASave%20and%20refresh%20again.%20Now%20your%20class%20is%20loaded%20and%20shows%20up%20in%20the%20class%20browser.%0A%0ANow%2C%20let%27s%20make%20this%20class%20do%20something.%20Create%20a%20new%20message%20in%20the%20class%20browser%20by%20navigating%20to%20your%20class%2C%20then%20clicking%20%27not%20yet%20classified%27%20and%20fill%20in%20a%20simple%20message.%20Try%20this%20for%20example%3A%0A%0A%20%20%20%20begin%0A%09%22Makes%20me%20say%20hello%20to%20the%20user.%22%0A%0A%09%7C%20msg%20button%20%7C%0A%09msg%20%3A%3D%20%27Hello%20world%21%27.%0A%09button%20%3A%3D%20%27%23sayHello%27%20asJQuery.%0A%09button%20click%3A%20%5Bbutton%20after%3A%20%27%3Cp%3E%27%20%2C%20msg%20%2C%20%27%3C/p%3E%27%5D.%0A%0AYour%20message%20isn%27t%20too%20helpful%20if%20it%20doesn%27t%20get%20called.%20Save%20it%2C%20commit%20the%20package%2C%20then%20edit%20index.html%20again.%20You%20can%20write%20JavaScript%20code%20that%20sends%20a%20message%20to%20Smalltalk%3A%0A%0A%20%20%20%20loadAmber%28%7B%0A%20%20%20%20%20%20%20%20files%3A%20%5B%27HelloApp.js%27%5D%2C%0A%20%20%20%20%20%20%20%20prefix%3A%20%27projects/hello/js%27%2C%20//%20path%20for%20js%20files%20i%20think%0A%20%20%20%20%20%20%20%20ready%3A%20function%28%29%20%7B%0A%20%20%20%20%20%20%20%20%20%20%24%28function%28%29%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20smalltalk.Hello._new%28%29._begin%28%29%3B%0A%20%20%20%20%20%20%20%20%20%20%7D%29%3B%0A%20%20%20%20%7D%7D%29%3B%20%0A%0AFrom%20there%2C%20you%20can%20create%20new%20Smalltalk%20classes%20and%20messages%20to%20build%20up%20your%20app.%20Enjoy%21%0A")]);})(smalltalk.send((smalltalk.DocChapter || DocChapter), "_new", []));
  828. return self;}
  829. }),
  830. smalltalk.TutorialsChapter);
  831. smalltalk.addMethod(
  832. '_counterChapter',
  833. smalltalk.method({
  834. selector: 'counterChapter',
  835. fn: function (){
  836. var self=this;
  837. return (function($rec){smalltalk.send($rec, "_title_", ["The counter application"]);return smalltalk.send($rec, "_contents_", [unescape("%0A%0AThis%20tutorial%20will%20teach%20you%20how%20to%20build%20HTML%20with%20Amber%20using%20jQuery%20and%20the%20HTMLCanvas%20API.%20It%20is%20freely%20adapted%20from%20%0Athe%20%5BSeaside%20counter%20example%5D%28http%3A//www.seaside.st/about/examples/counter%29%0A%0A%23%23The%20counter%20widget%0A%0AThe%20counter%20is%20the%20most%20basic%20example%20of%20a%20widget.%20It%20allows%20to%20increment%20and%20decrement%20a%20number%20by%20clicking%20a%20button.%0A%0AAmber%20already%20comes%20with%20a%20counter%20example%20in%20the%20%60Examples%60%20package.%20To%20avoid%20class%20name%20conflict%2C%20we%27ll%20name%20our%20counter%20class%20%60TCounter%60.%0A%0A%20%20%20%20Widget%20subclass%3A%20%23TCounter%0A%20%20%20%20%20%20%20%20instanceVariableNames%3A%20%27count%20header%27%0A%20%20%20%20%20%20%20%20package%3A%20%27Tutorials%27%0A%0AThe%20first%20method%20is%20used%20to%20initialize%20the%20component%20with%20the%20default%20state%2C%20in%20this%20case%20we%20set%20the%20counter%20to%200%3A%0A%0A%20%20%20%20initialize%0A%20%20%20%20%20%20%20%20super%20initialize.%0A%20%20%20%20%20%20%20%20count%20%3A%3D%200%0A%0AThe%20method%20used%20for%20rendering%20a%20widget%20is%20%60%23renderOn%3A%60.%20It%20takes%20an%20instance%20of%20HTMLCanvas%20as%20parameter.%20%0AThe%20%60header%60%20h1%20kept%20as%20an%20instance%20variable%2C%20so%20when%20the%20count%20value%20change%2C%20we%20can%20update%20it%27s%20contents%20accordingly.%0A%0A%20%20%20%20renderOn%3A%20html%0A%20%20%20%20%20%20%20%20header%20%3A%3D%20html%20h1%20%0A%20%20%20%20%20%20%20%20%20%20%20%20with%3A%20count%20asString%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20yourself.%0A%20%20%20%20%20%20%20%20html%20button%0A%20%20%20%20%20%20%20%20%20%20%20%20with%3A%20%27++%27%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20onClick%3A%20%5Bself%20increase%5D.%0A%20%20%20%20%20%20%20%20html%20button%0A%20%20%20%20%20%20%20%20%20%20%20%20with%3A%20%27--%27%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20onClick%3A%20%5Bself%20decrease%5D%0A%0AThe%20counter%20is%20almost%20ready.%20All%20we%20need%20now%20is%20to%20implement%20the%20two%20action%20methods%20%60%23increase%60%20and%20%60%23decrease%60%20to%20change%20the%20state%20%0Aof%20our%20counter%20and%20update%20its%20header.%0A%0A%20%20%20%20increase%0A%20%20%20%20%20%20%20%20count%20%3A%3D%20count%20+%201.%0A%20%20%20%20%20%20%20%20header%20contents%3A%20%5B%3Ahtml%20%7C%20html%20with%3A%20count%20asString%5D%0A%0A%20%20%20%20decrease%0A%20%20%20%20%20%20%20%20count%20%3A%3D%20count%20-%201.%0A%20%20%20%20%20%20%20%20header%20contents%3A%20%5B%3Ahtml%20%7C%20html%20with%3A%20count%20asString%5D%0A%0A%0AThat%27s%20it%21%20We%20can%20now%20display%20an%20instance%20of%20TCounter%20by%20rendering%20it%20on%20the%20page%20using%20jQuery%3A%0A%0A%20%20%20%20TCounter%20new%20appendToJQuery%3A%20%27body%27%20asJQuery%0A%0A")]);})(smalltalk.send((smalltalk.DocChapter || DocChapter), "_new", []));
  838. return self;}
  839. }),
  840. smalltalk.TutorialsChapter);