2
0

CHANGELOG 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438
  1. 20 January 2015 - Release 0.14.3
  2. ===================================
  3. Highlights:
  4. * Package can specify external dependencies and import them as package-global vars.
  5. Commits: https://github.com/amber-smalltalk/amber/compare/0.14.2...0.14.3
  6. Issues: https://github.com/amber-smalltalk/amber/issues?q=milestone%3A0.14.3+is%3Aclosed
  7. For the most important API related changes see the file API-CHANGES.txt.
  8. 11 January 2015 - Release 0.14.2
  9. ===================================
  10. Highlights:
  11. * Slimmed core - es5-shim and IE8 compatibilty tweaks in amber-compat-* repos.
  12. Commits: https://github.com/amber-smalltalk/amber/compare/0.14.1...0.14.2
  13. For the most important API related changes see the file API-CHANGES.txt.
  14. 8 January 2015 - Release 0.14.1
  15. ===================================
  16. Highlights:
  17. * Slimmed core - legacy IDE, Examples and Benchfib in own repo.
  18. * Smalltalk optOut: used instead allowJavaScriptCalls to make jQuery work.
  19. Commits: https://github.com/amber-smalltalk/amber/compare/0.14.0...0.14.1
  20. For the most important API related changes see the file API-CHANGES.txt.
  21. 1 January 2015 - Release 0.14.0
  22. ===================================
  23. Highlights:
  24. * Removed deprecated stuff and backward compatibility support code.
  25. * You can wrap any object using #asJQuery.
  26. Commits: https://github.com/amber-smalltalk/amber/compare/0.13.2...0.14.0
  27. Issues: https://github.com/amber-smalltalk/amber/issues?q=is%3Aissue+is%3Aclosed+milestone%3A0.14.0
  28. For the most important API related changes see the file API-CHANGES.txt.
  29. 31 December 2014 - Release 0.13.3
  30. ===================================
  31. This is a planned maintenance release.
  32. It contains everything 0.14.0 contains,
  33. but it retains all the backwards compatibility stuff,
  34. which is going to be removed in 0.14.0.
  35. 22 October 2014 - Release 0.13.2
  36. ===================================
  37. This is maintenance release to upgrade CodeMirror
  38. jointly in Amber and Helios.
  39. Highlights:
  40. * CodeMirror upgrade for Amber and Helios.
  41. * Cleaned of all (as far as findable) uses of deprecated code.
  42. * Recompile using `grunt` in Windows now does not add cr characters.
  43. Commits: https://github.com/amber-smalltalk/amber/compare/0.13.0...0.13.2
  44. For the most important API related changes see the file API-CHANGES.txt.
  45. 10 October 2014 - Release 0.13.1
  46. ===================================
  47. Highlights:
  48. * Reworked cleaner DNU handling in core.
  49. * `amber init` fully embraced as the way to create new project.
  50. * Helios IDE is extracted and is now a project on its own.
  51. * It is included as dev-dependency in any new project by default.
  52. * Movable data out of index.html:
  53. * list of production packages in deploy.js;
  54. * list of development packages in devel.js;
  55. * project amd mappings in local.amd.json;
  56. * libraries' amd mappings in lib_directory.amd.json.
  57. * 'Batteries included' deployment via `grunt deploy`.
  58. * 0.13.1 because of technical issues w/ 0.13.0 release process.
  59. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.6...0.13.0
  60. Issues: https://github.com/amber-smalltalk/amber/issues?q=is%3Aissue+is%3Aclosed+milestone%3A0.13.0
  61. For the most important API related changes see the file API-CHANGES.txt.
  62. 1 July 2014 - Release 0.12.6
  63. ===================================
  64. Highlights:
  65. * SUnit Runner in Helios IDE.
  66. * `amber` and `amberc` cli moved to `external` directory
  67. and to dedicated npm package.
  68. * Bootstrap 3 can be used in Amber projects
  69. (no more nameclash with Helios' bootstrap 2 using bootstrap2.3.2 name).
  70. * Wider range of jQuery versions allowed.
  71. * Amber now parses `$c` character literal.
  72. * `amber` is not to be installed globally any more.
  73. Instead, `npm install -g amber-cli` installs cli tooling.
  74. * After installing the cli tooling, `amber init` initializes
  75. new project if run in empty directory.
  76. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.4...0.12.6
  77. Issues: https://github.com/amber-smalltalk/amber/issues?milestone=13&state=closed
  78. For the most important API related changes see the file API-CHANGES.txt.
  79. 11 April 2014 - Release 0.12.4
  80. ===================================
  81. Highlights:
  82. * Fixed backward compatibility for pre-0.12.3 loader syntax.
  83. * `namespace/_source` is not needed to map and is recommended
  84. not to use; `.st` files are by default committed to the `.js` location.
  85. * All sources, including js files into the src/ directory
  86. * Many improvements in Helios, especially in its debugger and
  87. inspector, as well as UI-related improvements
  88. * New Helios dark theme by @BenjaminVanRyseghem
  89. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.3...0.12.4
  90. Issues: https://github.com/amber-smalltalk/amber/issues?milestone=12&state=closed
  91. For the most important API related changes see the file API-CHANGES.txt.
  92. 22 January 2014 - Release 0.12.3
  93. ===================================
  94. Highlights:
  95. * JQuery updated to ~1.10.2; jquery-ui updated to match
  96. * Subclasses of `nil` can be created
  97. * Several fixes for IE8
  98. * amber.js can be loaded asynchronously (it must
  99. have an id 'amber-path-mapper' in that case)
  100. * CodeMirror updated to ~3.20.0
  101. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.2...0.12.3
  102. Issues: https://github.com/amber-smalltalk/amber/issues?milestone=11&state=closed
  103. For the most important API related changes see the file API-CHANGES.txt.
  104. 3 December 2013 - Release 0.12.2
  105. ===================================
  106. Highlights:
  107. * Loading Amber in nested pages now possible (via additional `data-libs` attribute of the `<script>` tag which loads `amber.js`)
  108. * IDE related fixes
  109. * Contributions Guide
  110. * Improved Collections
  111. * Amber Server responds with `not found` instead of `internal server error` if `index.html` could not be found
  112. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.1...0.12.2
  113. Issues: https://github.com/amber-smalltalk/amber/issues?milestone=10&state=closed
  114. For the most important API related changes see the file API-CHANGES.txt.
  115. 14 November 2013 - Release 0.12.1
  116. ===================================
  117. Fixes a bug in Helios preventing class definitions from being compiled
  118. Commits: https://github.com/amber-smalltalk/amber/compare/0.12.0...0.12.1
  119. Issues: https://github.com/amber-smalltalk/amber/issues?milestone=9&state=closed
  120. 11 November 2013 - Release 0.12.0
  121. ===================================
  122. After 3 months of work we are pleased to announce the 0.12.0 release of Amber.
  123. Besides the usual bug fixes a lot of new features have emerged.
  124. The biggest change is the switch to RequireJS to specify Amber package dependencies
  125. and for loading the packages as AMD modules.
  126. Amber is now additionally available as Bower [2] component.
  127. Bower is also used to manage required JavaScript libraries which don't have to be kept
  128. around in the repository anymore.
  129. The repository layout was restructured to provide a cleaner separation of different Amber parts:
  130. * Smalltalk code is located in 'st'
  131. * Compiled Amber packages are located in 'js'
  132. * Supporting JavaScript code is located in 'support'
  133. Together with the RequireJS changes the specifying their dependencies the Brickz [3]
  134. reconfigurable micro composition system was introduced.
  135. This is used for
  136. On the Smalltalk side support has been added for writing exponential numbers of the form 2e5.
  137. Helios (the new IDE) is progressing nicely and has seen a lot of improvements.
  138. One of the great parts is the new stepping debugger which is also making progress.
  139. To try Helios, open the helios.html page or
  140. evaluate in any other amber page `require('amber/helpers').popupHelios()`.
  141. The last enhancements target the commandline compiler which can be used as
  142. `amberc` (an executable script) or as a Grunt task.
  143. The following features have been added:
  144. * generation of shebang line (#!/usr/bin/env node)
  145. * specification of target namespace (`-n` flag; `amd_namespace` option in Grunt)
  146. * specification of additional library directories (`-L` flag; `library_dirs` option in Grunt)
  147. The following features have been removed:
  148. * creation of *.deploy.js files (`-d` flag; `deploy` option in Grunt)
  149. * optimization passes via Closure compiler (`-o`/`-O` flags; `closure_jar` option in Grunt)
  150. The same behavior can be achieved by using specific Grunt tasks
  151. Additionally, the Grunt task now handles the -v/--verbose flag which triggers the same behavior
  152. as the `verbose` option which can be specified in the Gruntfile.
  153. Some numbers about this release (starting from 0.11.0):
  154. * 660 commits
  155. * 10 committers
  156. * 66 unit tests added
  157. * 152 issues were closed
  158. * 379 unit tests in total
  159. Commits: https://github.com/amber-smalltalk/amber/compare/0.11.0...0.12.0
  160. Issues: https://github.com/amber-smalltalk/amber/issues?direction=desc&milestone=8&page=1&sort=updated&state=closed
  161. For the most important API related changes see the file API-CHANGES.txt.
  162. * Installing Amber from NPM
  163. To install Amber from NPM, run
  164. npm install amber
  165. * Installing Amber from Bower
  166. To install Amber from Bower, run
  167. bower install amber
  168. * Migration from Amber 0.11.0
  169. First, the loading of JavaScript files must be adapted. The custom loader has been replaced with
  170. requirejs for loading files in the browser. New loader code is thouroughly
  171. explained in [4].
  172. After updating the loader part, `.st` files need to be recompiled
  173. into new AMD `.js` files. During loader changes, a namespace was choosen and will be needed for recompilation.
  174. Go to your directory with `.st` files and issue this from the shell:
  175. ```sh
  176. <path-to-amber>/bin/amberc -l SUnit,Canvas -n <chosen-namespace> -D <path-for-compiled-js-files> *.st
  177. ```
  178. In windows, use `\` as path separator, the rest is identical.
  179. The `-l SUnit,Canvas` is just a general guess, if your code depends on more (or less) non-kernel packages from amber, list them here accordingly.
  180. This migrate scenario only covers simple deployments with your project's code and amber.
  181. If your project is more complicated, using libraries and packages from multiple sources,
  182. it is hard to give general advices to migrate - you must do it library by library,
  183. giving each location its own namespace, and `-L` option of `amberc`
  184. comes handy when integrating; ask on the mailing list if problems arise.
  185. [1] http://requirejs.org/
  186. [2] http://bower.io/
  187. [3] https://github.com/amber-smalltalk/brikz
  188. [4] https://github.com/amber-smalltalk/amber/wiki/How-to-load-amber
  189. 9 July 2013 - Release 0.11.0
  190. ===============================
  191. Three months have passed and we are happy to announce the release
  192. of Amber 0.11.0!
  193. Some numbers about this release:
  194. * 494 commits
  195. * 13 committers
  196. * increasing the number of core committers to 25
  197. * 50 unit tests added to the kernel
  198. * 313 unit tests in total
  199. Since the last release 60 issues were closed, bringing us to 499
  200. issues closed.
  201. This release includes a lot of bug fixes, improvements to the
  202. CLI, as well as a preview of the next IDE, named Helios. Amber
  203. now also uses a CI server [1].
  204. To try the Helios, the new IDE, open the helios.html page, or
  205. evaluate in any other amber page `amber.loadHelios()`.
  206. The compiler also received some improvements, especially
  207. regarding message send optimisations and super sends.
  208. Here's the list of commits and closed issues:
  209. https://github.com/amber-smalltalk/amber/compare/0.10.0...0.11.0
  210. https://github.com/amber-smalltalk/amber/issues?direction=desc&milestone=6&page=1&sort=updated&state=closed
  211. There is a lot more to come with Helios, a stepping debugger
  212. based on the AST is in progress and currently in the 'debugger'
  213. branch on GitHub.
  214. * Installing Amber from NPM
  215. To install amber from NPM, run
  216. npm install amber
  217. * Migration from Amber 0.10.0
  218. Amber compiled code should be compatible with Amber 0.10.0, but
  219. recompiling is needed in order to get contexts working:
  220. Compiler new recompile: (Package named: 'MyPackage') classes.
  221. (Package named: 'MyPackage') commit
  222. For API related changes see the file API-CHANGES.txt.
  223. 13 March 2013 - Release 0.10.0
  224. ================================
  225. Here's a summary of change since the 0.9.1 release:
  226. - Travis CI jobs
  227. - Almost 300 issues closed
  228. - 150 new unit tests written
  229. - All classes in the Kernel are documented
  230. - New and much improved compiler toolchain, providing:
  231. - Semantic analysis
  232. - AST Node annotation
  233. - Intermediate representation (easier to optimize)
  234. - Better inlining
  235. - an AST interpreter
  236. - support for blocks contexts
  237. - New build system based on grunt.js, replacing the old makefiles
  238. - New bin/amberc compiler written in Amber/Node.js
  239. - SUnit improvements and cleanup, with support for async assertions
  240. - Improved ClassBuilder with better class migration support
  241. - Improved loader for third party packages
  242. - New: Announcements
  243. - Classes can be augmented by light-weight methods created from blocks
  244. - Snippets of HTML can be marked to become virtual tags in HTMLCanvas
  245. - Amber server supports Basic HTTP authentication (not recommended for production environments/unencrypted connections)
  246. - New IDE on it's way for Amber 1.0
  247. 16 January 2012 - Release 0.9.1
  248. =================================
  249. Here's a summary of changes since the 0.9 release:
  250. - 80 new unit tests written
  251. - 52 issues fixed
  252. - All classes in Kernel-Objects, Kernel-Classes and Kernel-Methods has been documented
  253. - New documentation framework (see http://amber-lang.net/documentation.html)
  254. - Better class organisations, "Kernel" package split into several packages
  255. - First class packages have replaced class categories
  256. - Internet Explorer 7+ compatibility
  257. - New Announcement framework ported from Pharo
  258. - New console-based REPL written in Amber using node.js
  259. - Symbol class implemented together with object identity and #==
  260. - New OrderedCollection and Set implementation
  261. - Dictionary can now have any kind of object as keys. String-key dictionary has been renamed HashedCollection
  262. - New TwitterWall example
  263. - Improved HTML Canvas, now compatible with IE7
  264. - Improved JSObjectProxy for seamless JavaScript objects access from Amber
  265. - No more jQuery binding. Amber is fully capable of sending messages to JavaScript objects
  266. 13 September 2011 - Release 0.9
  267. =================================
  268. Amber has been evolving furiously since the presentation at ESUG 2011 in Edinburgh less than 3 weeks ago.
  269. This is a summary:
  270. Language, compiler and runtime
  271. - New 100x faster parser built using PEGjs instead of the old parser built using PetitParser.
  272. - New much faster ChunkParser implementation in handwritten Amber instead of using PetitParser.
  273. - Improved parsing error report with quoted source code plus marker pinpointing parsing error.
  274. - Removed PetitParser since it is no longer needed by Amber itself.
  275. - Added compiler optimizations in the form of speculative inlining of specific messages and control structures.
  276. - Added support for dynamic Arrays, just like in Squeak/Pharo.
  277. - Added support for similar dynamic Dictionaries, not seen in other Smalltalks.
  278. - Added & and | as allowed binary selectors and implemented them in Boolean.
  279. - Added a Set implementation.
  280. - Added first basic support for real Packages with dependency information.
  281. ...and various extensions, enhancements and bug fixes to the library classes.
  282. Development environment
  283. - A working Debugger with integrated inspector, proceed etc.
  284. - A new structure with
  285. - A working amberc command line compiler including a Makefile for recompiling the whole Amber.
  286. - Enabled TestRunner in the IDE for running unit tests based on SUnit.
  287. - Added "File in" button in Workspace to easily paste and filein source code in chunk format in the IDE.
  288. Example code and ports
  289. - Ported ProfStef interactive tutorial, available on Amber homepage but also in examples directory.
  290. - Included the ESUG presentation as an example also in the examples directory.
  291. - Several new examples running on Node.js and webOS included, all with Makefiles.
  292. Various other things
  293. - Issue tracker on github now used as primary source, closed a bunch of reported issues.
  294. - Wiki pages on github with information on how to port code from other Smalltalks, lists of articles, tutorials, roadmap and more.