From Fedora Project Wiki
(Updated Erlang R16B status - I've fixed couchdb on my local machine)
(Updated Erlang R16B status - I've started investigation FTBFS issue with ejabberd)
Line 89: Line 89:
| {{package|couchdb}}  || {{no}} [https://bugzilla.redhat.com/913829 (FTBFS - w.i.p.)]
| {{package|couchdb}}  || {{no}} [https://bugzilla.redhat.com/913829 (FTBFS - w.i.p.)]
|-
|-
| {{package|ejabberd}} || {{no}} [https://bugzilla.redhat.com/913969 (FTBFS)]
| {{package|ejabberd}} || {{no}} [https://bugzilla.redhat.com/913969 (FTBFS - w.i.p.)]
|-
|-
| {{package|mochiweb}} || {{yes}}
| {{package|mochiweb}} || {{yes}}

Revision as of 13:34, 15 March 2013

Erlang/OTP R16

Summary

Update Erlang to the upstream R16 release.

Owners

  • email: lemenkov@gmail.com

Current status

  • Targeted release: Fedora 19
  • Last updated: 2013-03-12
  • Percentage of completion: 40%

Timeline

Detailed Description

Erlang is a general-purpose concurrent programming language and runtime system. The sequential subset of Erlang is a functional language, with strict evaluation, single assignment, and dynamic typing. For concurrency it follows the Actor model. It was designed by Ericsson to support distributed, fault-tolerant, soft-real-time, non-stop applications. The first version was developed by Joe Armstrong in 1986. It supports hot swapping, thus code can be changed without stopping a system. Erlang was originally a proprietary language within Ericsson, but was released as open source in 1998.

While threads are considered a complicated and error-prone topic in most languages, Erlang provides language-level features for creating and managing processes with the aim of simplifying concurrent programming. Though all concurrency is explicit in Erlang, processes communicate using message passing instead of shared variables, which removes the need for locks.

The above text was taken from en:wikipedia:erlang

The status of Erlang and related packages in Fedora/EPEL is shown at Erlang SIG page.

Benefit to Fedora

Several notable improvements (and incompatible changes) were introduced in this version. Some highlights are:

  • Optimized handling of processes in the VM
    • New internal process table allowing for parallel reads and writes
  • Dynamic allocation of port structures, allowing the default for maximum ports to be raised to 65536 (from 1024)
  • Full support for UTF-8 in the sources. The default file encoding will be ISO-Latin-1 in R16, but will be changed to UTF-8 in R17.
  • The Pman application has been superseded by the Observer application. Pman will be removed in R16.
  • Column numbers in compiler error messages which breaks compatibility regarding the abstract format but simplifies bug hunting even more.
  • The http client (from Inets application) now support HTTPS through a proxy
  • Asn1 application: Major cleanup of back ends and optimizations of mainly decode for PER and UPER.
  • Removal of the unsupported 'packages' from the R16.
  • A beginning of the removal of the parametrized modules. This affects mochiweb.
  • Several gen_tcp speedups.
  • Dialyzer optimizations
  • Multicore improvements, parallel code loading.
  • All sources are fully covered by type specs. BIFs are visible in erlang sources (as NIFs).
  • Fully supports the unstable development branch of wxWidgets-2.9.

See full changelog for the detailed description of changes:

Scope

Required steps are:

  • Rebuilding Erlang/OTP itself. DONE!
  • Fix all broken packages. I expect DLL loader issues in all packages which contain so-objects ue to major API version mismatch. All of them must be rebuilt with new Erlang.
    • erlang-basho_metrics - REBUILT.
    • erlang-bitcask - REBUILT.
    • erlang-ebloom - REBUILT.
    • erlang-eleveldb - REBUILT.
    • erlang-emmap - REBUILT.
    • erlang-esasl - REBUILT.
    • erlang-esdl - REBUILT.
    • erlang-gtknode - rebuild isn't necessary. This neither a driver, nor a NIF library.
    • erlang-js - REBUILT.
    • erlang-skerl - REBUILT.
    • erlang-snappy - REBUILT.
  • Fix all packages which requires parametrized modules (I already rebuild mochiweb with the patch which fixes it).

How To Test

  • Ensure that high-grade Erlang applications are still working:
Name Tested
couchdb No (FTBFS - w.i.p.)
ejabberd No (FTBFS - w.i.p.)
mochiweb Yes
rabbitmq-server No (FTBFS)
riak No (FTBFS - w.i.p.)
wings No
  • Collect feedback from volunteers regarding their experience with this Erlang/OTP version

Contingency Plan

None necessary. Instead of falling back to the previous version we should fix existing packages in order to help the Community. We should also monitor upstream development process for potentially discovered issues and proactively apply patches (as we already did with Erlang R14 and Erlang R15).

Documentation

Release Notes

Erlang/OTP R16B is available in Fedora 19.

Comments and Discussion