Content deleted Content added
mNo edit summary |
Add external links to the current source code for Miranda and a large example of a Miranda program |
||
(26 intermediate revisions by 18 users not shown) | |||
Line 1:
{{Short description|Programming language by David Turner}}
{{
{{Infobox programming language
| name
| logo
| logo caption
| screenshot
| screenshot caption
| file ext
| paradigm
| scope
| released = {{Start date and age|1985}}▼
▲ | designer = [[David Turner (computer scientist)|David Turner]]
▲ | developer = Research Software Ltd
| latest release version = {{wikidata|property|edit|reference|P348}}
| latest release date
| latest preview version =
| latest preview date
| typing
| implementations
| dialects
| influenced by
| influenced
| programming language
| platform
| operating system
| license = {{wikidata|property|edit|reference|P275}}
| website
| wikibooks
}}
'''Miranda''' is a [[lazy evaluation|lazy]], [[functional programming|purely functional]] [[programming language]] designed by [[David Turner (computer scientist)|David Turner]] as a successor to his earlier programming languages [[SASL programming language|SASL]] and [[Kent Recursive Calculator|KRC]], using some concepts from [[ML (programming language)|ML]] and [[Hope (programming language)|Hope]].
Miranda was first released in 1985 as a fast interpreter in [[C (programming language)|C]] for [[Unix]]-flavour operating systems, with subsequent releases in 1987 and 1989. It had a strong influence on the later [[
In 2020 a version of Miranda was released as open source under a [[BSD 2-Clause|BSD licence]]. The
== Name ==
[[File:Miranda - The Tempest JWW.jpg|thumb|right|''Miranda'' by John William Waterhouse, 1917]]
The name ''Miranda'' is taken from the gerundive form of the latin verb {{lang|la|[[:wikt:miror|miror]]}},<ref>{{cite web |url=https://www.cs.kent.ac.uk/people/staff/dat/miranda/name.html |title=About the name Miranda |access-date=2024-05-18}}</ref> meaning "to be admired".
The logo features a rendition by [[John William Waterhouse]] of the character [[Miranda (The Tempest)|Miranda]] from Shakespeare's ''The Tempest''.
== Overview ==
Miranda is a [[lazy evaluation|lazy]], [[functional programming|purely functional]] programming language. That is, it lacks [[Side effect (computer science)|side effect]]s and [[imperative programming]] features. A Miranda program (called a ''script'') is a set of [[equation]]s that define various mathematical [[function (mathematics)|function]]s and [[algebraic data type]]s. The word ''[[
Since the [[parsing]] algorithm makes intelligent use of layout (indentation, via [[off-side rule
[[Comment (computer programming)|Comment]]ary is introduced into regular scripts by the characters <code>||</code> and continue to the end of the same line. An alternative commenting convention affects an entire source code file, known as a "[[Literate programming|literate script]]", in which every line is considered a comment unless it starts with a <code>></code> sign.
Line 48 ⟶ 55:
</syntaxhighlight>
The ''[[
<syntaxhighlight lang="haskell">
Line 88 ⟶ 95:
The notation for function application is simply juxtaposition, as in <code>sin x</code>.
In Miranda, as in most other purely functional languages, functions are [[first-class function|first-class]] citizens, which is to say that they can be passed as [[parameter (computer science)|arguments]] to other functions, returned as results, or included as elements of data structures.
<syntaxhighlight lang="haskell">
Line 104 ⟶ 111:
</syntaxhighlight>
is the briefest way to create a function that adds one to its argument.
<syntaxhighlight lang="haskell">
Line 168 ⟶ 175:
fak :: num -> num
fak 0 = 1
fak n = n *
Line 256 ⟶ 263:
isAvl (N l w r) = and (isAvl l) (isAvl r), if amount ((nodecount l) - (nodecount r)) < 2
= False, otherwise
delete :: * -> tree * -> tree *
delete x E = E
Line 273 ⟶ 280:
==External links==
* {{Official website}}
* [https://codeberg.org/DATurner/miranda The currently maintained open source version] of Professor Turner's interpreter for Miranda.
* [http://bignum.sf.net The infinite precision math library], a large example of programming in Miranda (and Haskell).
{{Programming language}}
{{Authority control}}
Line 280 ⟶ 290:
[[Category:Functional languages]]
[[Category:History of computing in the United Kingdom]]
[[Category:Programming languages created in 1985]]
|