Wren Versions Save

The Wren Programming Language. Wren is a small, fast, class-based concurrent scripting language.

0.4.0

3 years ago

0.4.0 contains 145 commits from 28 contributors!

About Wren

Release blog post (highlights only).

Documentation

This release includes many documentation revisions, fixes, additions and gaps closed!

Language

Modules

Fixes

API

Other

  • build; add util/generate_projects.py for regenerating project files
  • vm; Allow computed goto when using clang on Windows
  • vm; WREN_MAX_TEMP_ROOTS default is 8 (instead of 5)
  • vm; GC debug times are printed in milliseconds, not seconds

Commits since 0.3.0

0.4.0-pre

3 years ago

This release is a draft.

Language

Modules

Fixes

API

Other

  • build; add util/generate_docs.py for regenerating project files
  • vm; Allow computed goto when using clang on Windows
  • vm; WREN_MAX_TEMP_ROOTS default is 8 (instead of 5)
  • vm; GC debug times are printed in milliseconds, not seconds

Commits since 0.3.0

0.3.0

3 years ago

Blog

Read the 0.3.0 release blog for more details, and plans for 0.4.0.

Note You can try Wren on http://wren.io/try, and Wren CLI now has downloads.

0.3.0 changelog

0.3.0 is a fairly specific release, aimed at fixing build issues across platforms, streamlining the process for new users and making embedding easier. This is a stepping stone for working on language features and improving the VM, hacking on the docs and the VM is simpler than ever!

Builds now work out of the box on all primary platforms. Previously there was issues on Windows and other platforms due to unix-ey workflows being the default.

All the python scripts have also been fixed and updated (to python 3), and work consistently across all platforms out of the box too (including the tests, benchmarks, metrics etc). Like before, there was some things that didn't hold up on Windows or Mac. Fixed!

A lot of work has been done to also clarify the distinction between the CLI project and the VM, as well as move the CLI to it's own repo! This removes a lot of code that wasn't being used, and also been clarified the project structure.

Docs have also had a clean up, and a new page to try Wren directly on the doc page was added.

Language/VM

  • CLI moved to own repo
  • Use premake for project generation, see projects/
  • Fix builds across platforms. "Just works" on all primary platforms.
  • Fix amalgamated script generator and amalgamated build
  • Fix unicode parsing and other issues in all python scripts
  • All python scripts are python3 now, and run on all platforms correctly
  • Test runner isolated and unified for VM tests
  • Remove SASS and Pygments requirements from docs, just python now
  • Updated docs to clarify VM/CLI split
  • Added Try page for running wren code in the docs

0.2.0

4 years ago

Blog

Read the 0.2.0 release blog for details, and plans for 0.3.0.

0.2.0 changelog

0.2.0 spans a pretty wide time period with around 290 commits. This includes many bug fixes, improvements, clarity in the code and documentation and so on. There are some minor API changes, be sure your header is up to date so the compiler can tell you what changed. There's too many changes to explicitly list, so below is the obvious user facing stuff that was easy to spot in the history.

Most noteworthy is that 'relative imports' are a slightly breaking change, but help pave the way forward toward a consistency for modules.

Language/VM

  • import was made smarter, differentiating relative from logical
  • Fiber can now accept a value from the first call/transfer
  • Improved performance/distribution of number hashing (details)
  • Added String.trim, String.trimEnd, String.trimStart variants
  • Added String.split, String.replace, String.fromByte
  • Added String.indexOf(needle, startIndex)
  • Added Sequence.take and Sequence.skip
  • Added Num.pow, Num.log, Num.round
  • Added Num.largest, Num.smallest
  • Added List.filled(count, value)
  • Added Map iteration (MapEntry)

C API

  • Added wren.hpp for use in c++
  • Added void* user data to WrenVM
  • Added wrenAbortFiber
  • Allow hosts with no module loader to still load optional modules.

CLI

Please note that beyond 0.2.0 the CLI will have it's own changelog. This list is not exhaustive. For a fuller history see the commit log above.

  • Add path module
  • Add --version
  • Add REPL written in Wren
  • Add Stdin.isTerminal
  • Added Platform class
  • Rename process module to os