Joule (programming language)

From Wikipedia, the free encyclopedia
Joule
Paradigm(s) multi-paradigm: object-oriented, distributed, Dataflow
Appeared in 1996
Designed by E. Dean Tribble
Typing discipline untyped
Influenced by Concurrent Logic Programming, Actors
Influenced E

    Joule is a concurrent dataflow programming language, designed for building distributed applications. It is so concurrent that the order of statements within a block is irrelevant to the operation of the block. Statements are executed whenever possible, based on their inputs. Everything in Joule happens by sending messages. There is no control flow. Instead, the programmer describes the flow of data, making it a dataflow programming language.

    It is considered the precursor to the E programming language.

    Language syntax

    Numerals consist of ASCII digits 0-9; identifiers are Unicode sequences of digits, letters, and operator characters that begin with a letter. It is also possible to form identifiers by using Unicode sequences (including whitespace) enclosed by either straight (' ') or standard (‘ ’) single quotes, where the backslash is the escape character. Keywords have to start with a letter, except the keyword to send information. Operators consist of Unicode sequences of digits, letters, and operator characters, beginning with an operator character. Labels are identifiers followed by a colon (':').[1]

    At the root, Joule is an imperative language and because of that a statement-based language. It has a rich expression syntax, which transforms easily to its relational syntax underneath. Complex expressions become separate statements, where the site of the original expression is replaced by a reference to the acceptor of the results channel. Therefore, nested expressions still compute completely concurrently with their embedding statement.[1]

       If amount <= balance
           • account withdraw: amount
       else
           • account report-bounce:
       end

    An identifiers may name a channel to communicate with the server. If this is the case, it is said to be bound to that channel.[1]

    References

    1. 1.0 1.1 1.2 Joule: Distributed Application Foundations: 4.2. Expressions (PDF) 1. Agorics, Inc. 20 December 2004. pp. 31–33. Retrieved 2012-08-29. 

    External links


    This article is issued from Wikipedia. The text is available under the Creative Commons Attribution/Share Alike; additional terms may apply for the media files.