Concatenative programming language: Difference between revisions

Content deleted Content added
(edited with ProveIt)
m WP:REFerence WP:CITations: repeats consolidate-merge as WP:NAMEDREFS, cuts.
 
(53 intermediate revisions by 38 users not shown)
Line 1:
{{Short description|Type of programming language}}
<!-- {{bare URLs|date=June 2013}} -->
{{Programming paradigms}}
 
A '''concatenative programming language''' is a [[Point-free programming|point-free]] computer [[programming language]] in which all expressions denote [[Function (mathematics)|functions]], and the [[juxtaposition (mathematics)|juxtaposition]] of [[Expression (computer science)|expressions]] denotes [[function composition]].<ref name="dobbscodetalk">{{cite webmagazine |last1=Diggins |first1=Christopher |date=2008-12-31 |url=http://drdobbs.com/blogs/architecture-and-design/228701299 |title=Christopher Diggins: What is a concatenative language |publishermagazine=Drdobbs[[Dr.com Dobb's Journal]] |access-date=2008-12-31 |accessdate=2013-07-01}}</ref> Concatenative programming replaces [[function application]], which is common in other [[programming stylesparadigm]]s, with [[functionFunction composition (computer science)|function composition]] as the default way to build [[subroutine]]s. Functions and procedures written in concatenative style typically don't represent the data structures they operate on with explicit names or [[identifier#InFunction (computer science|identifiers]]; instead, a function is defined as a [[pipeline (softwareprogramming)|pipelinesubroutines]] - a sequence of operations that take parameters from an implicit data structure on which all functions operate, and return the function results to that shared structure so that it will be used by the next operator.<ref>{{cite web | url=http://concatenative.org/wiki/view/Concatenative%20language | title=Concatenative language | publisher=Concatenative.org | accessdate=13 September 2013}}</ref>
 
==Example==
The combination of a compositional [[Semantics of programming languages|semantics]] with a [[Syntax of programming languages|syntax]] that mirrors such a semantics makes concatenative languages highly amenable to algebraic manipulation.<ref>[http://www.latrobe.edu.au/philosophy/phimvt/joy/j00rat.html Rationale for Joy, a functional language]{{dead link|date=July 2013}}</ref>
For example, a nesting of operations in an applicative language like the following:
 
<syntaxhighlight lang="javascript">
Much of the original work on concatenative language theory was carried out by [[Manfred von Thun]].
baz(bar(foo(x)))
</syntaxhighlight>
 
...is written in a concatenative language as a sequence of functions:<ref>{{cite web |url=http://concatenative.org/wiki/view/Concatenative%20language/Name%20code%20not%20values |title=Name code not values |publisher=Concatenative.org |access-date=13 September 2013}}</ref>
==Properties==
 
x foo bar baz
 
Functions and procedures written in concatenative style are not [[Value-level programming|value level]], i.e., they typically do not represent the data structures they operate on with explicit names or [[Identifier#In computer science|identifiers]]. Instead they are [[Function-level programming|function level]] – a function is defined as a [[pipeline (software)|pipeline]], or a sequence of operations that take parameters from an implicit [[data structure]] on which all functions operate, and return the function results to that shared structure so that it will be used by the next operator.<ref>{{cite web |url=http://concatenative.org/wiki/view/Concatenative%20language |title=Concatenative language |publisher=Concatenative.org |access-date=13 September 2013}}</ref>
 
The combination of compositional [[Semantics (computer science)|semantics]] with a [[Syntax (programming languages)|syntax]] that mirrors such a semantic makes concatenative languages highly amenable to algebraic manipulation of programs;<ref>{{cite web |url=http://www.latrobe.edu.au/philosophy/phimvt/joy/j00rat.html |archive-url=https://web.archive.org/web/20110115151536/http://www.latrobe.edu.au/philosophy/phimvt/joy/j00rat.html |archive-date=2011-01-15 |title=Rationale for Joy, a functional language}}</ref> although it may be difficult to write mathematical expressions directly in them.<ref name="whymatters"/> Concatenative languages can be implemented efficiently with a [[stack machine]], and are commonly present implicitly in [[virtual machine]]s in the form of their [[instruction set]]s.<ref name="whymatters">{{cite web |last1=Purdy |first1=Jon |date=12 February 2012 |url=http://evincarofautumn.blogspot.com/2012/02/why-concatenative-programming-matters.html |title=Why Concatenative Programming Matters |website=The Big Mud Puddle |access-date=12 August 2025}}</ref>
 
==Properties==
The properties of concatenative languages are the result of their compositional syntax and semantics:
 
* The reduction of any expression is the simplification of one function to another function; it is never necessary to deal with the application of functions to objects.<ref>[{{cite web |last1=von Thun |first1=Manfred |year=2011 |url=http://www.latrobe.edu.au/phimvt/joy/j08cnt.html |title=Joy compared with other functional languages] |archive-url=https://web.archive.org/web/20111006225512/http://www.latrobe.edu.au/phimvt/joy/j08cnt.html |archive-date=2011-10-06}}</ref>
* Any subexpression can be replaced with a name that represents the same subexpression. ThisIn isconcatenative referredprogramming topractice, inthis the concatenative communityis ascalled [[Code refactoring|factoring]], and is used extensively to simplify programs into smaller parts.
* The syntax and semantics of concatenative languages form the algebraic structure of a [[monoid]].<ref>[{{cite web |last1=von Thun |first1=Manfred |year=2009 |url=http://www.latrobe.edu.au/philosophy/phimvt/joy/j02maf.html von Thun, Manfred: |title=Mathematical foundations of Joy]{{dead link|datearchive-url=Julyhttps://web.archive.org/web/20100731060810/http://www.latrobe.edu.au/philosophy/phimvt/joy/j02maf.html 2013|archive-date=2010-07-31}}</ref>
* Concatenative languages can be made well-suited to an implementation inspired by [[linear logic]] where no [[Garbage (computer science)|garbage]] is ever generated.<ref>{{cite webreport |last1=Baker |first1=Henry |year=1993 |url=http://home.pipeline.com/~hbaker1/ForthStack.html |title=Henry Baker: Linear Logic and Permutation Stacks: The Forth Shall Be First |publisher=Nimble Computer Corporation |via=Home.pipeline.com |access-date=2013-07-01 |accessdatearchive-url=2013https://web.archive.org/web/20140724091729/http://home.pipeline.com/~hbaker1/ForthStack.html |archive-date=2014-07-0124 |url-status=dead}}</ref>
 
==Implementations==
The first concatenative programming language was [[Forth (programming language)|Forth]], although [[Joy (programming language)|Joy]] was the first language which was termed concatenative. Other concatenative languages are [[dc (computer program)|dc]], [[Factor (programming language)|Factor]], Onyx, [[PostScript]], [[RPL (programming language)|RPL]], Staapl,<ref name="Staapl">{{cite web |last1=Schouten |first1=Tom (zwizwa) |date=<!-- Undated --> |url=http://zwizwa.be/staapl/ |title=Staapl: Forth on Scheme for Embedded Controllers |website=Zwizwa LLC |access-date=12 August 2025}}</ref> and experimental and discontinued ones including:<!-- Alphabetic order--> Enchilada,<ref name="Enchilada">{{cite web |author1=rapido |author2=NewDave |author3=jacintheford |author4=goren |date=2 January 2024 |url=https://concatenative.org/wiki/view/Enchilada |title=Enchilada |website=Concatenative.org |access-date=12 August 2025}}</ref> Om,<ref name="Om">{{cite web |author1=sparist |date=<!-- Undated --> |url=https://www.om-language.com/ |title=The Om Programming Language |website=Om-language.com |access-date=12 August 2025}}</ref> XY.<ref name="XY">{{cite web |last1=Apter |first1=Stevan |date=2004 |url=http://www.nsl.com/k/xy/xy.htm |title=The Concatenative Language XY |website=no stinking loops |access-date=12 August 2025}}</ref>
 
Most existing concatenative languages are [[Stack-oriented programming|stack-based]]. This is not required, and other models have been proposed.<ref name="XY"/><ref name="Enchilada"/><ref name="Om"/> Concatenative languages are currently used for [[Embedded system|embedded]],<ref name="Staapl"/> [[Application software|desktop]], and [[Web development|web programming]], as [[Translator (computing)|target languages]], and for research purposes.
The first concatenative programming language was [[Forth (programming language)|Forth]], although [[Joy (programming language)|Joy]] was the first language to call itself concatenative. Other concatenative languages are [[Cat (programming language)|Cat]], [[Enchilada (programming language)|Enchilada]], [[Factor (programming language)|Factor]], [[Onyx (programming language)|Onyx]], [[PostScript]], [[RPL (programming language)|RPL]], [[Staapl]], [[Trith (programming language)|Trith]], [[XY (programming language)|XY]], and [[Om (programming language)|Om]].
 
Most existing concatenative languages are [[stack-baseddynamically typed]];. thisExceptions isinclude notthe a[[statically requirementtyped]] andCat other models have been proposed.language<ref>{{cite web|url=http://www.nslcat-language.com/k/xy/xymanual.htmhtml |title=TheCat Concatenative Language XYSpecification |publisher=NslCat-language.com |access-date= |accessdate=2013-07-01}}</ref><ref>{{cite web|archive-url=httphttps://wwwweb.enchiladacodearchive.nlorg/ |title=The Enchilada Programming Language |publisher=Enchiladacodeweb/20150205081218/http://cat-language.nlcom/manual.html |archive-date= |accessdate=20132015-0702-0105}}</ref> and its successor, Kitten<ref>{{citeCite web |urllast1=http://www.om-language.org/Purdy |first1=Jon |title=The OmKitten Programming Language |publisherurl=Om-languagehttps://kittenlang.org/ |access-date=2025-03-31 |accessdatewebsite=2013-07-01kittenlang.org}}</ref> Concatenative languages are currently used for [[embedded systems|embedded]], [[Application software|desktop]], and [[web programming]], as [[target language]]s, and for research purposes.
 
Most concatenative languages are [[dynamically typed]]. One exception is the [[statically typed]] Cat language.<ref>{{cite web|url=http://www.cat-language.com/manual.html |title=Cat Specification |publisher=Cat-language.com |date= |accessdate=2013-07-01}}</ref>
 
==See also==
* [[Function-level programming]]
* [[Homoiconicity]]
* [[Stack-oriented programming language]]
* [[Tacit programming]]
* [[Homoiconicity]]
 
==References==
Line 35 ⟶ 43:
 
==External links==
* [http://www.concatenative.org/ concatenativeConcatenative.org: A wikiWiki], about concatenative languages]programming
* [http://zwizwa.be/staapl Staapl: Forth on Scheme for Embedded Controllers]
* [http://www.enchiladacode.nl The Enchilada Programming Language]
* [http://www.nsl.com/k/xy/xy.htm The Concatenative Language XY]
* [http://om-language.org The Om Programming Language]
 
{{DEFAULTSORT:Concatenative Programming Languageparadigms navbox}}
[[Category:Concatenative{{Types of programming languages]]}}
 
{{DEFAULTSORT:Concatenative Programming languageLanguage}}
[[Category:Concatenative programming languages| ]]
<!-- Hidden categories below -->
[[Category:Articles with example JavaScript code]]