Developing concurrent programs with Pony
Subtyping
Listing 5 shows yet a further incompatibility in capabilities: The history
declaration stipulates box
(line 3), whereas in line 10, res
attempts to insert an iso
reference using push()
.
Of course consume
deletes res
; however, without the capability references, you could not write a meaningful program in Pony. Figure 5 shows the possible replacements that work in the direction of the arrow. For example, an iso
can replace any other capability, but trn
can only be used for val
or ref
, because trn
permits additional read references of the box
capability, which would contradict the exclusive character of iso
. However, val
can be replaced by trn
after a consume
removes the last writing reference of trn
type.
If you replace ref
, you can allow other writing references without problems. The box
and tag
capabilities are not critical for val
and ref
because the latter cannot write. A blog post by developer John Mumm provides a more detailed explanation [9].
Blue Horses
The main.pony
file shown in Listing 6 is the entry point in the example program; in the tradition of C, Pony uses main
as the identifier for the program start point.
Like the familiar main()
function in C or the main()
method in Java, Pony defines an actor. In line 4, the actor's constructor accepts a reference to the executing environment of the program as an object of type Env
. The next lines save the reference in the field with the name env
in the Main
instance.
Line 6 creates the actor of type Painter
, as defined by Listing 5. The constructor uses this
to receive simultaneously a reflexive reference to the Main
actor. The for
loop in lines 7 to 10 iterates over the field with the primitives [Amber, Blue, Crimson, Other]
or, preferably, its iterator object.
On the basis of field values, line 8 generates an object of type Resource
, as defined in Listing 3, and stores the reference in the run-time variable x
. The expression recover Resource(x) end
introduces a mechanism for arbitrarily setting a capability. In the present form, recover
generates a reference of type iso
.
Line 9 transfers the resource
to the Painter
actor. A further deletion process, courtesy of consume res
, occurs before sending. As mentioned earlier, Painter
finally calls the notify
behavior in line 12. The message is a String
type and ends up in the shell thanks to the env
object.
Conclusions
Thanks to Pony, programmers can write what looks to be secure, high-performance code for concurrent programs. It is free of data races and deadlocks and follows the style of object-oriented languages. The actor model should not cause any trouble, but the difficulty of understanding capabilities could deter many users. The matter is even more complex when developers need to consider the resulting effects of a collection of several capabilities.
If the complexity does not deter you, you can improve the quality of your multithreaded programs; moreover, Pony can be docked on existing projects by integrating C code via the Foreign Function Interface (FFI).
Infos
- Pony: http://ponylang.org
- Actor model: http://www.brianstorti.com/the-actor-model/
- Capabilities: http://man7.org/linux/man-pages/man7/capabilities.7.html
- Rust: http://rust-lang.org
- Java 9 plans: http://openjdk.java.net/projects/jdk9/spec/
- Dynamic classes (citation 7): https://en.wikipedia.org/wiki/Comparison_of_programming_languages_by_type_system#cite_note-7
- Pony on GitHub: https://github.com/ponylang/ponyc
- The concept of ownership in Rust: https://doc.rust-lang.org/book/ownership.html
- Sharing reference capabilities: http://jtfmumm.com/blog/2016/03/06/safely-sharing-data-pony-reference-capabilities/
« Previous 1 2 3
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Canonical Releases Ubuntu 24.04
After a brief pause because of the XZ vulnerability, Ubuntu 24.04 is now available for install.
-
Linux Servers Targeted by Akira Ransomware
A group of bad actors who have already extorted $42 million have their sights set on the Linux platform.
-
TUXEDO Computers Unveils Linux Laptop Featuring AMD Ryzen CPU
This latest release is the first laptop to include the new CPU from Ryzen and Linux preinstalled.
-
XZ Gets the All-Clear
The back door xz vulnerability has been officially reverted for Fedora 40 and versions 38 and 39 were never affected.
-
Canonical Collaborates with Qualcomm on New Venture
This new joint effort is geared toward bringing Ubuntu and Ubuntu Core to Qualcomm-powered devices.
-
Kodi 21.0 Open-Source Entertainment Hub Released
After a year of development, the award-winning Kodi cross-platform, media center software is now available with many new additions and improvements.
-
Linux Usage Increases in Two Key Areas
If market share is your thing, you'll be happy to know that Linux is on the rise in two areas that, if they keep climbing, could have serious meaning for Linux's future.
-
Vulnerability Discovered in xz Libraries
An urgent alert for Fedora 40 has been posted and users should pay attention.
-
Canonical Bumps LTS Support to 12 years
If you're worried that your Ubuntu LTS release won't be supported long enough to last, Canonical has a surprise for you in the form of 12 years of security coverage.
-
Fedora 40 Beta Released Soon
With the official release of Fedora 40 coming in April, it's almost time to download the beta and see what's new.